Java开源项目部署阿里云Ubuntu 16.04 LTS

核心步骤

  1. 阿里云准备 Linux 16.04,安全组设置(可以虚拟机代替)
  2. linux下jdk maven git 配置
  3. 添加SSH公钥从gitee克隆源代码
  4. liunx下docker安装
  5. docker下mysql安装
  6. git拉取项目代码
  7. 执行项目中sql的数据库脚本
  8. 修改项目配置并启动

环境部署

准备工作

  • 阿里云

    centos_8_0_x64_20G_alibase_20200218.vhd

[root@iZ2zeeqw5fxmm9zagf439aZ ~]# cat /etc/redhat-release

CentOS Linux release 8.1.1911 (Core)

[root@iZ2zeeqw5fxmm9zagf439aZ ~]#

注意阿里云需要安全组端口设置,不然无法访问

image-20241231112239424

以上目录非必须,可以自行选择安装路径。

  • 新建目录

    1
    2
    3
    4
    5
    6
    #tmp存放临时安装包
    mkdir -p /data/tmp
    #service存放软件环境
    mkdir -p /data/service
    #gitee存放代码版本控制库
    mkdir -p /data/gitee

    以上目录非必须,可以自行选择安装路径。

  • JDK >= 1.8 (推荐1.8版本)

    从oracle官方网站上下载1.8版本中的最新版的JDK。下载完成后,把文件通过WinSCP或者XFTP上传到服务器上。接着进行解压和配置环境变量。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    #进入安装包目录,解压
    cd /data/tmp
    tar -zxvf jdk-8u431-linux-x64.tar.gz

    #把解压出来的文件夹转移到统一的地方
    mv /data/tmp/jdk1.8.0_431 /data/service/jdk1.8.0_431

    #修改环境变量/etc/profile,JAVA_HOME修改为自己的jdk路径。
    vim /etc/profile
    export JAVA_HOME=/data/service/jdk1.8.0_431
    export PATH=$PATH:$JAVA_HOME/bin

    #使环境变量生效
    source /etc/profile

    #检查是否配置成功
    java -version
  • vim语法

    vim +路径+文件名

    按a开始编辑

    编辑完成之后,按esc(保持英文状态),然后

    • 如果你没有做任何改变,输入 :q,然后按 Enter/return
    • 如果你做了一些改变,并希望保留它们,输入 :wq 并按 Enter/return
    • 如果你做了一些改变,并希望强制保留它们,输入 :wq! 并按 Enter/return
    • 如果你做了一些修改,并希望放弃它们,请输入 :q! 并按 Enter/return
  • Maven >= 3.0

    从Maven官方网站上下载最新版的压缩包。下载完成后,进行解压和配置环境变量。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    #进入安装包目录,解压
    tar -zxvf apache-maven-3.9.9-bin.tar.gz

    #修改环境变量/etc/profile,MAVEN_HOME修改为自己的jdk路径。
    export MAVEN_HOME=/data/service/maven-3.9.9
    export PATH=$PATH:$MAVEN_HOME/bin

    #使环境变量生效
    source /etc/profile

    #检查是否配置成功
    mvn -v
  • Git

    1
    2
    3
    4
    5
    6
    #通过apt安装,本方法最简单。但是无法控制安装的版本
    sudo apt update
    sudo apt install git

    #检查是否配置成功
    git --version
    1
    2
    ssh-keygen -t rsa -C "xx@xx.com"
    cat ~/.ssh/id_rsa.pub
  • Mysql >= 5.5.0 (推荐5.7版本)

    使用docker的方式安装mysql,首先安装docker

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    sudo apt update
    sudo apt-get remove docker docker-engine docker.io containerd runc
    # 更新包列表并安装必要的依赖
    sudo apt-get update
    sudo apt-get install apt-transport-https ca-certificates curl software-properties-common

    # 添加 Docker 的官方 GPG 密钥
    curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

    # 验证指纹(可选)
    sudo apt-key fingerprint 0EBFCD88

    # 添加 Docker 稳定版仓库
    sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
    # 再次更新包列表以包含新添加的仓库
    sudo apt-get update

    # 安装 Docker CE
    sudo apt-get install docker-ce docker-ce-cli containerd.io
    # 启动 Docker 服务
    sudo systemctl start docker

    # 设置 Docker 开机自启
    sudo systemctl enable docker

为了加快镜像下载速度,您可以配置Docker使用阿里云提供的镜像加速服务(登录阿里云搜索即可)

1
2
3
4
5
6
7
  # 编辑或创建 Docker 配置文件,请将<Your_Accelerator>替换为您从阿里云获取的实际加速地址。
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<EOF
{
"registry-mirrors": ["https://<Your_Accelerator>.mirror.aliyuncs.com"]
}
EOF

重启 Docker 服务以应用更改

sudo systemctl daemon-reload
sudo systemctl restart docker

1

#查看可用的 MySQL 版本
docker search mysql
#拉取5.7版本
docker pull mysql:5.7
#创建配置文件目录
mkdir -p /data/docker/mysql/conf
#进入配置文件目录,添加一个配置文件
vim my.cnf
#启动镜像
docker run -p 3306:3306 –name mysql -v /data/docker/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

1


[mysqld]
character-set-server=utf8

[mysql]
default-character-set=utf8

1


#进入docker容器设置env LANG=C.UTF-8
docker exec -it mysql env LANG=C.UTF-8 bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22



注意3:如果使用docker进入mysql数据库执行包含中文的sql语句,出现中文乱码的情况,需要在容器系统中设置使用中文包。所以进入docker容器时需要设置环境语言:

注意2:在mysql的镜像启动之前,创建配置文件目录,并放置好配置文件。这样mysql启动的时候,就可以直接使用配置好的参数。以下内容是配置数据库的字符集为utf-8。

注意1:MySQL(5.7.19)的默认配置文件是 /etc/mysql/my.cnf 文件。如果想要自定义配置,建议向 /etc/mysql/conf.d 目录中创建 .cnf 文件。新建的文件可以任意起名,只要保证后缀名是 cnf 即可。

在Docker中安装MySQL。

注意:如果安装docker-ce报错,可以执行以下语句,再进行安装。

- 安装之后,在git仓库中需要添加SSH公钥

### 项目部署

**部署步骤**

1. 从git仓库clone下来最新代码。ruoyi项目的gitee地址是https://gitee.com/y_project/RuoYi



#创建git仓库目录,clone项目源代码
mkdir -p /data/gitee
cd /data/gitee
git clone git@gitee.com:y_project/RuoYi.git
#复制需要执行的sql文件到docker的映射目录中
cp /data/gitee/RuoYi/sql/quartz.sql /data/docker/mysql/conf/
cp /data/gitee/RuoYi/sql/ry_20200911.sql /data/docker/mysql/conf/

#进入docker容器中,执行sql文件
docker exec -it mysql env LANG=C.UTF-8 bash
#连接mysql
mysql -uroot -p
#创建数据库ruoyi
create database if not exists ruoyi character set=’utf8’;
#进入数据库,执行文件
use ruoyi;
source /etc/mysql/conf.d/quartz.sql;
source /etc/mysql/conf.d/ry_20200911.sql;
cd /data/gitee/RuoYi/ruoyi-admin/src/main/resources/
#修改application.yml的项目启动端口号
vim application.yml
#修改application-druid.yml的数据源
vim application.yml
server:
port: 18081

ruoyi:
profile: /data/tmp

数据源配置

spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driverClassName: com.mysql.cj.jdbc.Driver
druid:
# 主库数据源
master:
url: jdbc:mysql://localhost:3306/ruoyi?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: root
password: 123456
cd /data/gitee/RuoYi/
mvn install

1
2
3

2.启动项目:把jar复制到程序目录,通过java命令行的方式启动jar包文件。因为本项目是使用了spring boot框架,所以jar中内置了web容器,不需要额外安装tomcat了。

mkdir -p /data/app/ruoyi-admin
cp /data/gitee/RuoYi/ruoyi-admin/target/ruoyi-admin.jar /data/app/ruoyi-admin/ruoyi-admin.jar
cd /data/app/ruoyi-admin/
nohup java -jar ruoyi-admin.jar &


nohup和&用来表示本命令需要在后台执行,这样退出命令行程序后,java程序也不会停止

**部署问题**

1.本教程中设置的端口是18081,所以可以通过http://服务器公网IP:18081的方式进行访问

如果显示502,有可能安全组没有设置18081端口

2.排除第一个之后,如果还是无法访问,则**查看nohup输出**

```tail -f nohup.out```