友情提示:因为部署的是我自己的项目,所以有些工具是我自用的,不需要的可以不用安装。
环境与插件
- 操作系统: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
- 安装特定版本的 Docker Engine-Community,请在仓库中列出可用版本,然后选择一种安装。列出您的仓库中可用的版本:
apt-cache madison docker-ce
- 使用第二列中的版本字符串安装特定版本,例如 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
打印出以下信息则安装成功
查看版本
docker -v
安装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
Docker安装Redis
查看redis来源
docker search redis
拉取镜像
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
测试
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
远程连接出现的问题
- 看MySQL的用户是不是限制了远程登录,也就是看host是localhost还是%
mysql> SELECT user, host FROM mysql.user;
上图不正常
mysql> update user set host = '%' where user = 'root'; mysql> flush privileges;
- 查看3306端口是否打开
netstat -talnp
如果使用的是ECS,设置安全配置规则,允许访问端口
测试
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
访问http://ip:15672
安装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
访问
建立映射
查看容器
docker ps
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>
访问
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
ls
制作镜像
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
执行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