Docker发布前后端分离项目

友情提示:因为部署的是我自己的项目,所以有些工具是我自用的,不需要的可以不用安装。

环境与插件

  • 操作系统:Ubuntu 18.04
  • jdk: 1.8
  • Docker: 19.03.13
  • Redis: 6.0.9
  • Mysql: 5.7
  • Nginx: 1.10
  • wkhtmltopdf
  • 前后端分离:
    前端:Vue
    后端:Spring Boot

Docker

更新apt 包索引

sudo apt-get update

安装 apt 依赖包,用于通过HTTPS来获取仓库

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    gnupg-agent \
    software-properties-common

添加 Docker 的官方 GPG 密钥

curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

设置稳定版仓库

sudo add-apt-repository \
   "deb [arch=amd64] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/ \
  $(lsb_release -cs) \
  stable"

更新apt源索引

sudo apt-get update

安装最新版本的 Docker Engine-Community 和 containerd ,或者转到下一步安装特定版本:

sudo apt-get install docker-ce docker-ce-cli containerd.io
  1. 安装特定版本的 Docker Engine-Community,请在仓库中列出可用版本,然后选择一种安装。列出您的仓库中可用的版本:
apt-cache madison docker-ce
image.png
  1. 使用第二列中的版本字符串安装特定版本,例如 5:19.03.12 ~ 3-0~ubuntu-bionic
sudo apt-get install docker-ce=<VERSION_STRING> docker-ce-cli=<VERSION_STRING> containerd.io

测试 Docker 是否安装成功

sudo docker run hello-world

打印出以下信息则安装成功


image.png

查看版本

docker -v
image.png

安装jdk

官网下载.gz包

官网下载地址

解压

sudo mkdir /usr/local/java
sudo tar -zxvf jdk-8u271-linux-x64.tar.gz -C /usr/local/java

环境变量

sudo vim /etc/profile

export JAVA_HOME=/usr/local/java/jdk

export CLASSPATH=.:${JAVA_HOME}/lib

export PATH=${JAVA_HOME}/bin:$PATH

立即生效

source /etc/profile

查看安装

java -version
image.png

Docker安装Redis

查看redis来源

docker search redis
image.png

拉取镜像

docker pull redis:6.0.9

创建映射文件

redis.conf: 官网下载

修改配置文件:

bind 127.0.0.1: #注释掉这部分,这是限制redis只能本地访问
daemonize no:#默认no,改为yes意为以守护进程方式启动,可后台运行,除非kill进程,改为yes会使配置文件方式启动redis失败
appendonly yes: #redis持久化
requirepass foobared: #修改密码

mkdir /alidata/docker/redis
vim /alidata/docker/redis/redis.conf

创建容器

docker run -p 6379:6379 --name redis -v /alidata/docker/redis/redis.conf:/etc/redis/redis.conf -v /alidata/docker/redis/data:/data -d redis:6.0.9 redis-server /etc/redis/redis.conf --appendonly yes

命令解释说明:

-p 6379:6379: 端口映射:前表示主机部分,:后表示容器部分。

--name redis: 指定该容器名称,查看和进行操作都比较方便。

-v: 挂载目录,规则与端口映射相同。

为什么需要挂载目录:个人认为docker是个沙箱隔离级别的容器,这个是它的特点及安全机制,不能随便访问外部(主机)资源目录,所以需要这个挂载目录机制。

-d redis:6.0.9: 表示后台启动redis

redis-server /etc/redis/redis.conf: 以配置文件启动redis,加载容器内的conf文件,最终找到的是挂载的目录/alidata/docker/redis/redis.conf

测试

image.png

Docker安装Mysql

拉取镜像

docker pull mysql:5.7

创建映射文件

mkdir /alidata/docker/mysql/data
mkdir /alidata/docker/mysql/logs
vim /alidata/docker/mysql/conf/my.cnf

创建容器

docker run \
  -p 3306:3306 \
  --name mysql \
  -v /alidata/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf \
  -v /alidata/docker/mysql/logs:/logs \
  -v /alidata/docker/mysql/data:/var/lib/mysql \
  -e MYSQL_ROOT_PASSWORD=root \
  -d mysql:5.7

命令解释说明:

-e MYSQL_ROOT_PASSWORD=root 设置登录密码

进入容器

docker exec -it mysql bash

进入mysql

mysql -u root -p ##输入登录密码root

远程登录mysql

连接宿主机的IP ,指定端口为3306

远程连接出现的问题

image
  1. 看MySQL的用户是不是限制了远程登录,也就是看host是localhost还是%
mysql> SELECT user, host FROM mysql.user;
image

上图不正常

mysql> update user set host = '%' where user = 'root';
mysql> flush privileges;
  1. 查看3306端口是否打开
netstat -talnp 
image
  1. 如果使用的是ECS,设置安全配置规则,允许访问端口


    image.png

测试

image.png

Docker安装RabbitMQ

拉取镜像

docker pull rabbitmq:3.7

创建容器并启动

docker run -d --name rabbit -p 15672:15672 -p 5672:5672 -p 61613:61613 rabbitmq:3.7

注:这边需要用到stomp插件,所以需要将61613端口映射到宿主机上,看个人需求

安装STOMP插件

进入容器

docker exec -it rabbit bash

手动开启mq管理插件

rabbitmq-plugins enable rabbitmq_management

手动开启STOMP插件

rabbitmq-plugins enable rabbitmq_stomp
image.png

访问http://ip:15672

image.png

安装wkhtmltopdf

官网

下载

wget https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.xenial_amd64.deb

下载依赖

sudo apt-get install libxfont1 xfonts-encodings xfonts-utils xfonts-base xfonts-75dpi

安装wkhtmltopdf

sudo dpkg -i wkhtmltox_0.12.6-1.xenial_amd64.deb

wkhtmltopdf工具的路径在/usr/local/bin/wkhtmltopdf

测试

wkhtmltopdf https://www.baidu.com/ test.pdf

中文乱码

下载simsun.ttc/usr/share/fonts(可以在Windows里面找)

Docker安装Nginx

拉取镜像

docker pull nginx:1.10

创建映射文件

mkdir /alidata/docker/nginx/logs
mkdir /alidata/docker/nginx/conf

启动容器

docker run --name nginx-test -p 80:80 -d nginx:1.10

访问

image.png

建立映射

查看容器

docker ps
image.png

copy配置文件

docker cp 1c1245efec1d:/etc/nginx/nginx.conf /alidata/docker/nginx/conf

创建Nginx容器,并将www,logs,conf目录映射到本地,启动

docker run -d --name nginx \
  -p 8082:80 \
  -v /alidata/www/histo/pcp:/usr/share/nginx/html \
  -v /alidata/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
  -v /alidata/docker/nginx/logs:/var/log/nginx \
  nginx:1.10

参数说明:

--name nginx:容器名称。
-p 81:80: 端口进行映射,将本地 81 端口映射到容器内部的 80 端口。
-d nginx:1.10: 设置容器在在后台一直运行。

创建页面

/alidata/www/histo/pcp/index.html

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>docker搭建nginx</title>
</head>
<body>
    <h1>Docker部署nginx成功</h1>
</body>
</html>

访问

image.png

Docker部署前端(待更)

编译

编译后的文件拷贝至/alidata/www/histo/pcp/

配置niginx

Docker部署后端

获取项目

git clone 项目地址

构建项目

mvn clean
mvn install

编写Dockerfile文件

# 基础镜像使用java
FROM java:8
# 作者
MAINTAINER xxx@qq.com
# 将jar包添加到容器中并更名为pcp.jar
ADD ./target/*.jar pcp.jar
# 容器内应用将会使用容器的指定端口
EXPOSE 10999
# 运行jar包
ENTRYPOINT java -jar pcp.jar

制作镜像方式一

将编译好的项目和Dockerfile上传服务器

### 上传至/alidata/application/pcp/pcp
image.png

ls

image.png

制作镜像

docker build -t pcp .

启动容器

docker run -d --name pcp -p 10999:10999 pcp

制作镜像方式二

阿里云新建docker镜像上传的云端地址

这个自己去阿里云上新建,免费的

配置build.sh脚本

docker rmi registry.cn-shanghai.aliyuncs.com/xxx/yyy:${1}
docker build -t registry.cn-shanghai.aliyuncs.com/xxx/yyy:${1} .
docker login --username=xxx --password=xxx registry.cn-shanghai.aliyuncs.com
docker push registry.cn-shanghai.aliyuncs.com/xxx/xxx:${1}

进入项目,打开git bash

image.png

执行build.sh脚本

sh build.sh {{version}}

拉镜像

docker pull registry.cn-shanghai.aliyuncs.com/xxx/yyy:{{version}}

启动容器

docker run -d --name pcp -p 10999:10999 pcp

推荐阅读更多精彩内容