Centos7服务器配置Docker运行SpringBoot项目
文章目录
一、准备工作
本文讲述的是服务版本,所以需要下载SecureCRT工具,数据库Mysql8.0.17,SpringBoot版本2.1.9。
二、Centos7安装Docker
1.卸载旧版本
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
2.安装 Docker Engine-Community
在新主机上首次安装 Docker Engine-Community 之前,需要设置 Docker 仓库。之后,您可以从仓库安装和更新 Docker。
设置仓库
安装所需的软件包。yum-utils 提供了 yum-config-manager ,并且 device mapper 存储驱动程序需要 device-mapper-persistent-data 和 lvm2。
sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
使用以下命令来设置稳定的仓库。
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
3.安装 Docker Engine-Community
安装最新版本
sudo yum install docker-ce docker-ce-cli containerd.io
要安装特定版本的 Docker Engine-Community,请在存储库中列出可用版本,然后选择并安装:
a、列出并排序您存储库中可用的版本。此示例按版本号(从高到低)对结果进行排序。
yum list docker-ce --showduplicates | sort -r
b、通过其完整的软件包名称安装特定版本,该软件包名称是软件包名称(docker-ce)加上版本字符串(第二列),从第一个冒号(:)一直到第一个连字符,并用连字符(-)分隔。例如:docker-ce-18.09.1。
sudo yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io
4.启动Docker
sudo systemctl start docker
5.镜像加速
vim /etc/docker/daemon.json
#输入
{
"registry-mirrors": ["http://hub-mirror.c.163.com"]
}
#然后退出保存
#重启服务
sudo systemctl daemon-reload
sudo systemctl restart docker
三、Docker安装Mysql8.0.17
sudo docker pull mysql:8.0.17#下载镜像
sudo docker images#查看镜像
mkdir -p ~/mysql_8.0.17/data ~/mysql_8.0.17/log ~/mysql_8.0.17/conf#创建目录
cd ~/mysql_8.0.17#进入目录
#docker run :创建一个新的容器并运行一个命令,不管是否成功运行都会创建一个容器
sudo docker run -p 3306:3306 --name mysql8 -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=1234 -d mysql:8.0.17
#显示所有容器,包括未运行的
sudo docker ps -a
#如果run命令出现错误,但是容器已经创建,可以使用start命令运行
sudo docker start 容器id或name
#停止
sudo docker stop 容器id或name
#启动成功后,进入容器
docker exec -it 容器id或name bash
#登录mysql数据库
mysql -uroot -p
#修改root密码,非必要
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的密码';
#添加远程登录用户,非必要
CREATE USER '用户名'@'%' IDENTIFIED WITH mysql_native_password BY '你的密码';
GRANT ALL PRIVILEGES ON *.* TO '用户名'@'%';#一定设置,否则可能会出CannotGetJdbcConnectionException异常
run命令说明
- -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
- -v -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。
- -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。
- -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。
- -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
四、SpringBoot项目配置
server:
port: 8080
servlet:
context-path: /sign
spring:
datasource:
username: 用户#一定是要有权限的用户
password: 密码
url: jdbc:mysql://localhost:3306/数据库?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true
driver-class-name: com.mysql.cj.jdbc.Driver#mysql6或以上需要这样写
将项目打包成jar,并且上传到服务器可以使用java -jar XXX.jar运行项目,即可。