• 附录
    • 1. 安装问题
      • 1.1 Java部署
        • ① 安装包下载
        • ② 配置环境变量
        • ③ 查看版本
      • 1.2. 数据库部署
        • ① 安装MariaDB
        • ② 授权访问和添加用户
        • ③ 测试连接和创建数据库
      • 1.3. Zookeeper部署
    • 2. 常见问题
      • 2.1 脚本没权限
      • 2.2 构建失败

    附录

    1. 安装问题

    1.1 Java部署

    此处给出简单步骤,供快速查阅。更详细的步骤,请参考官网。

    ① 安装包下载

    从官网下载对应版本的java安装包,并解压到服务器相关目录

    1. mkdir /software
    2. tar -zxvf jdkXXX.tar.gz /software/

    ② 配置环境变量

    • 修改/etc/profile
    1. sudo vi /etc/profile
    • 在/etc/profile末尾添加以下信息
    1. JAVA_HOME=/nemo/jdk1.8.0_181
    2. PATH=$PATH:$JAVA_HOME/bin
    3. CLASSPATH==.:$JAVA_HOME/lib
    4. export JAVA_HOME CLASSPATH PATH
    • 重载/etc/profile
    1. source /etc/profile

    ③ 查看版本

    1. java -version

    1.2. 数据库部署

    此处以Centos安装MariaDB为例。MariaDB数据库是 MySQL 的一个分支,主要由开源社区在维护,采用 GPL 授权许可。MariaDB完全兼容 MySQL,包括API和命令行。其他安装方式请参考MySQL官网。

    ① 安装MariaDB

    • 安装命令
    1. sudo yum install -y mariadb*
    • 启停
    1. 启动:sudo systemctl start mariadb.service
    2. 停止:sudo systemctl stop mariadb.service
    • 设置开机启动
    1. sudo systemctl enable mariadb.service
    • 初始化
    1. 执行以下命令:
    2. sudo mysql_secure_installation
    3. 以下根据提示输入:
    4. Enter current password for root (enter for none):<–初次运行直接回车
    5. Set root password? [Y/n] <– 是否设置root用户密码,输入y并回车或直接回车
    6. New password: <– 设置root用户的密码
    7. Re-enter new password: <– 再输入一次你设置的密码
    8. Remove anonymous users? [Y/n] <– 是否删除匿名用户,回车
    9. Disallow root login remotely? [Y/n] <–是否禁止root远程登录,回车
    10. Remove test database and access to it? [Y/n] <– 是否删除test数据库,回车
    11. Reload privilege tables now? [Y/n] <– 是否重新加载权限表,回车

    ② 授权访问和添加用户

    • 使用root用户登录,密码为初始化设置的密码
    1. mysql -uroot -p -h localhost -P 3306
    • 授权root用户远程访问
    1. mysql > GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
    2. mysql > flush PRIVILEGES;
    • 创建test用户并授权本地访问
    1. mysql > GRANT ALL PRIVILEGES ON *.* TO 'test'@localhost IDENTIFIED BY '123456' WITH GRANT OPTION;
    2. mysql > flush PRIVILEGES;

    安全温馨提示:

    • 例子中给出的数据库密码(123456)仅为样例,强烈建议设置成复杂密码
    • 例子中root用户的远程授权设置会使数据库在所有网络上都可以访问,请按具体的网络拓扑和权限控制情况,设置网络和权限帐号

    ③ 测试连接和创建数据库

    • 登录数据库
    1. mysql -utest -p123456 -h localhost -P 3306
    • 创建数据库
    1. mysql > create database db_transaction;

    1.3. Zookeeper部署

    此处给出简单步骤,供快速查阅。详情请参考官网。

    (1)从官网下载对应版本的安装包,并解压到相应目录

    1. mkdir /software
    2. tar -zxvf zookeeper-XXX.tar.gz /software/

    (2)配置和启动

    ZooKeeper的安装包括单机模式安装,以及集群模式安装。具体步骤请参考官网说明:

    • 集群部署
    • 单机部署

    2. 常见问题

    2.1 脚本没权限

    执行shell脚本报错误permission denied。

    答:使用 “chmod +x 文件” 给文件增加权限

    2.2 构建失败

    “gradle build -x test”失败,不能编译Lombok注解:

    1. ...
    2. /data/trans/webase-transcation/src/main/java/com/webank/webase/transaction/trans/TransService.java:175: error: cannot find symbol
    3. log.warn("save fail. contract is not deploed", contractAddress);
    4. ^
    5. symbol: variable log
    6. location: class TransService
    7. /data/trans/webase-transcation/src/main/java/com/webank/webase/transaction/trans/TransService.java:183: error: cannot find symbol
    8. log.warn("call fail. contractAddress:{} abi is not exists", contractAddress);
    9. ^
    10. symbol: variable log
    11. location: class TransService
    12. Note: /data/trans/webase-transcation/src/main/java/com/webank/webase/transaction/util/ContractAbiUtil.java uses unchecked or unsafe operations.
    13. Note: Recompile with -Xlint:unchecked for details.
    14. 100 errors
    15.  
    16. FAILURE: Build failed with an exception.
    17. ...

    答: 修改 build.gradle文件,将以下代码的注释去掉

    1. //annotationProcessor 'org.projectlombok:lombok:1.18.2'