一、docker安装mysql5.7
1.安装docker
docker 在线安装:
docker离线安装:
2.拉取镜像
docker pull registry.cn-hangzhou.aliyuncs.com/fuyonghai/mysql:5.7
3.创建挂载目录
mkdir -p /data/docker/mysql5.7/data /data/docker/mysql5.7/logs /data/docker/mysql5.7/conf
cd /data/docker/mysql5.7/conf
touch my.cnf
4.启动容器
docker run --name mysql57 -p 3306:3306 \
-v /etc/localtime:/etc/localtime:ro \
-v /data/docker/mysql5.7/conf:/etc/mysql/conf.d \
-v /data/docker/mysql5.7/logs:/logs \
-v /data/docker/mysql5.7/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=Aigw1234! \
-d registry.cn-hangzhou.aliyuncs.com/fuyonghai/mysql:5.7
5.设置时间
# 如果容器已经创建且创建时未使用挂载时间文件启动时需要设置时间同步(注意时间同步一般在容器启动时就要设置)
docker cp /usr/share/zoneinfo/Asia/Shanghai mysql:/etc/localtime
6.登录验证
查看容器
[root@master1 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0f0dca8b6499 registry.cn-hangzhou.aliyuncs.com/fuyonghai/mysql:5.7 "docker-entrypoint.s…" 8 days ago Up 7 seconds 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql57
进入容器
[root@master1 ~]# docker exec -it 0f0 /bin/bash
bash-4.2#
root登录
#到这一步能登录则说明数据库没问题,但如果需要使用如navicat工具来连接的时候则需要配置防火墙开通3306端口
bash-4.2# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.44 MySQL Community Server (GPL)
Copyright (c) 2000, 2023, Oracle and/or its affiliates.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
查询数据库
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.03 sec)
退出数据库
mysql> \q
Bye
bash-4.2#
二、docker安装redis
1.拉取redis
docker pull redis:5.0.12
2.创建挂载目录
[root@VM-16-14-centos ~]# mkdir -p /opt/redis/data /opt/redis/conf
3.官网下载配置文件
[root@VM-16-14-centos ~]# cd /opt/redis/conf
[root@VM-16-14-centos conf]# wget http://download.redis.io/redis-stable/redis.conf
4.配置文件的修改
1、注释掉配置文件中 bind 127.0.0.1 -::1 ,解除本地连接限制
2、修改 protected-mode yes 为 protected-mode on,保护模式,限制为本地访问,修改后解除保护模式
3、修改 daemonize yes 为 daemonize on,修改为守护进程
4、修改密码 requirepass 密码
5.redis启动
[root@VM-16-14-centos conf]# docker run -d --name redis -p 6379:6379 \
-v /etc/localtime:/etc/localtime:ro \
-v /opt/redis/conf/redis.conf:/redis.conf \
-v /opt/redis/data:/data \
redis-server \
--appendonly yes \
--requirepass 123456 \
redis:5.0.12
6.参数解释
-p 6379:6379 端口映射:前表示主机部分,:后表示容器部分。
--name myredis 指定该容器名称,查看和进行操作都比较方便。
-v 挂载文件或目录 :前表示主机部分,:后表示容器部分。
-d redis 表示后台启动redis
redis-server 默认路径配置文件 /redis.conf
–appendonly yes 开启redis 持久化
–requirepass 输入设置的密码
7.登录验证
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
dc440112fa00 redis:5.0.12 "docker-entrypoint.s…" 7 seconds ago Up 4 seconds 0.0.0.0:6379->6379/tcp, :::6379->6379/tcp redis
[root@VM-16-14-centos conf]# docker exec -it redis /bin/bash
root@1489f3ceae54:/data# redis-cli
127.0.0.1:6379> auth 密码
OK
127.0.0.1:6379> ping
PONG
连接redis成功后,如果要清空redis某个缓存库如下操作
127.0.0.1:6379> select 0
127.0.0.1:6379> flushdb
127.0.0.1:6379>
查看redis中database为0库中所以的key
127.0.0.1:6379> select 0
127.0.0.1:6379> keys *
“sys:cache:dict::user_status:1”
“sys:cache:dict::user_status:2”
“geteway_routes”
“sys:cache:dict::sex:2”
“sys:cache:dict::sex:1”
如果清空database为8的缓存如下
127.0.0.1:6379> select 8
127.0.0.1:6379> flushdb
127.0.0.1:6379>
如果要清空redis全部database,如下
127.0.0.1:6379> flushall
127.0.0.1:6379>
127.0.0.1:6379> exit
root@1489f3ceae54:/data# exit
exit
[root@VM-16-14-centos conf]#
三、docker安装tomcat
1.拉取镜像
docker pull tomcat
2.启动容器
如果是启动了就直接用请注意设置时间参数 -v /etc/localtime:/etc/localtime:ro
docker -d --name my_web --restart always -p 8080:8080 tomcat:8.5.46-jdk8-openjdk
3.复制容器内部tomcat到宿主机中
docker cp my_web:/usr/local/tomcat/ /data/
4.挂载启动tomcat
docker -d --name my_web --restart always -p 8080:8080 \
-v /etc/localtime:/etc/localtime:ro \
-v /data/tomcat/data:/usr/local/tomcat/webapps/ROOT/ \
tomcat:8.5.46-jdk8-openjdk
5.使用tomcat
你把项目文件传到/data/tomcat/data下即可
6.重启tomcat
docker restart my_web
7.登录验证
验证部署是否成功:浏览器地址栏输入ip能返回页面则成功
注意防火墙设置
四、docker安装nginx
1.拉取镜像
docker pull registry.cn-hangzhou.aliyuncs.com/fuyonghai/aigw_nginx:latest
2.启动镜像
#(这一步是为了获取nginx相关的配置文件)
docker run --name mynginx -d -p 80:80 registry.cn-hangzhou.aliyuncs.com/fuyonghai/aigw_nginx:latest
3.创建挂载目录
#(用于宿主机配置文件后自动更新到容器内部)
mkdir -p /opt/nginx/html
mkdir -p /opt/nginx/log
mkdir -p /opt/nginx/conf
4.复制配置文件
docker cp aigw_web:/etc/nginx/nginx.conf /opt/nginx/conf/nginx.conf
docker cp aigw_web:/etc/nginx/conf.d /opt/nginx/conf/conf.d
docker cp aigw_web:/usr/share/nginx/html/ /opt/nginx
5.停止并删除容器
docker stop 容器id
docker rm 容器id
6.挂载重新启动容器
docker run -d -p 80:80 --name mynginx_xuming --privileged --restart always \
-v /etc/localtime:/etc/localtime:ro \
-v /opt/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /opt/nginx/conf/conf.d:/etc/nginx/conf.d \
-v /opt/nginx/html:/usr/share/nginx/html \
-v /opt/nginx/log:/var/log/nginx \
registry.cn-hangzhou.aliyuncs.com/fuyonghai/aigw_nginx:latest
7.验证
验证部署是否成功:浏览器地址栏输入ip能返回页面则成功
注意防火墙设置
8.配置ssl
配置步骤
1.需要到阿里云或其他厂商申请ssl证书,申请完证书后到下载页签下载nginx对应的证书文件,分别有两个,一个为 .key 另一个为 .pem;
2.在挂载目录中创建ssl文件,如/opt/nginx/conf/conf.d/ssl,将证书上传到服务器挂载ssl目录下,这里一定要注意宿主机挂载到容器中的路径具体是什么,配置文件中写路径时一定要写容器中的路径,不能写宿主机的路径,因为原理就是放在宿主机中的文件会同步到容器对应的目录下,当启动容器时加载的其实是容器中对应路径下的配置文件;
3.修改配置文件,将监听的80端口重定向到443 ,然后配置上ssl路径,然后检查容器启动时是否也映射了443端口启动,若没有映射则将容器停止删除,重新映射端口并启动容器即可
具体配置
1.上传的ssl证书,注意对应到容器中的实际路径是/etc/nginx/conf/conf.d/ssl
[root@aigw ssl]# pwd
/opt/nginx/conf/conf.d/ssl
[root@aigw ssl]# ls
www.aigw.top.key www.aigw.top.pem
2.修该配置文件内容如下
配置80转发443
server {
listen 80;
server_name www.aigw.top;
# 将HTTP请求重定向到HTTPS
return 301 https://$host$request_uri;
}
server {
#listen 80;
#listen [::]:80;
#server_name localhost;
listen 443 ssl;
server_name www.aigw.top;
ssl_certificate /etc/nginx/conf.d/ssl/www.aigw.top.pem;
ssl_certificate_key /etc/nginx/conf.d/ssl/www.aigw.top.key;
#access_log /var/log/nginx/host.access.log main;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
9.删除容器重启
docker ps #查看容器
docker stop 容器id #停止容器
docker rm 容器id #删除容器
#启动容器
docker run -d -p 80:80 -p 443:443 --name www.aigw.top --privileged --restart always \
-v /etc/localtime:/etc/localtime:ro \
-v /opt/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /opt/nginx/conf/conf.d:/etc/nginx/conf.d \
-v /opt/nginx/html:/usr/share/nginx/html \
-v /opt/nginx/log:/var/log/nginx \
registry.cn-hangzhou.aliyuncs.com/fuyonghai/aigw_nginx:latest
10.验证
打开浏览器输入域名直接访问,地址栏中的小锁呈现锁住的状态即配置成功
五、docker安装nacos
docker安装nacos2.4.2
单机部署
1.获取镜像
docker login --username=yonghai_fu registry.cn-hangzhou.aliyuncs.com
docker pull registry.cn-hangzhou.aliyuncs.com/fuyonghai/nacos-server:v2.4.2
2.创建挂载目录
# 创建本地挂载目录
mkdir -p /home/docker/nacos/conf/
mkdir -p /home/docker/nacos/logs/
mkdir -p /home/docker/nacos/data/
3.启动容器
# 这里只是简单启用,用于将nacos容器的的相关文件复制到挂载目录
docker run --name nacos -d -p 8848:8848 -e MODE=standalone registry.cn-hangzhou.aliyuncs.com/fuyonghai/nacos-server:v2.4.2
4.复制容器文件
# 复制容器中相关配置文件到挂载目录 注意本地后边路径没有带相应的文件夹是因为复制目录过去后会导致重复了两层同名目录,其实在创建目录时可以只创建/home/docker/nacos 也可以的。
docker cp nacos:/home/nacos/conf/ /home/docker/nacos/
docker cp nacos:/home/nacos/logs/ /home/docker/nacos/
docker cp nacos:/home/nacos/data/ /home/docker/nacos/
5.创建数据库
#1默认数据库已安装,这里用了msyql5.7 其他版本的数据库大同小异
#2使用navicat或者直接进入命令终端创建名为nacos的数据库
#3进入到上边的配置文件挂载目录/home/docker/nacos/conf 找到mysql-schema.sql 将文件内容传到创建的nacos数据库中执行创建相关的表以及数据。执行后能生成如下表则数据表创建成功。
config_info
config_info_aggr
config_info_beta
config_info_tag
config_tags_relation
group_capacity
his_config_info
permissions
roles
tenant_capacity
tenant_info
users
#4
6.修改配置文件
找到配置文件application.properties,并先备份,避免配置文件损坏无法恢复
cp application.properties application_bk.properties
vim 打开配置文件 找到下面的相关字段修改如下
server.servlet.contextPath=/nacos
server.contextPath=/nacos
server.port=8848
#*************** Config Module Related Configurations ***************#
### Deprecated configuration property, it is recommended to use `spring.sql.init.platform` replaced.
spring.datasource.platform=mysql
spring.sql.init.platform=mysql
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=1
db.url.0=jdbc:mysql://192.168.10.90:3306}/nacos?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}
db.user.0=root
db.password.0=Aigw1234!
nacos.core.auth.enable.userAgentAuthWhite=false
nacos.core.auth.server.identity.key=nacosKey
nacos.core.auth.server.identity.value=nacosValue
7.停止并删除容器
docker stop 容器id/名字
docker rm 容器id/名字
8.挂载启动容器
docker run --name nacos -d -p 8848:8848 -p 9848:9848 -p 9849:9849 --restart always \
--privileged=true \
-e JVM_XMX=256m \
-e JVM_XMS=256m \
-e MODE=standalone \
-e PREFER_HOST_MODE=hostname \
-e SPRING_DATASOURCE_PLATFORMSPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=192.168.10.90 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_DB_NAME=nacos \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=Aigw1234! \
-e MYSQL_DATABASE_NUM=1 \
-v /etc/localtime:/etc/localtime:ro \
-v /home/docker/nacos/conf/:/home/nacos/conf \
-v /home/docker/nacos/logs/:/home/nacos/logs \
-v /home/docker/nacos/data/:/home/nacos/data \
registry.cn-hangzhou.aliyuncs.com/fuyonghai/nacos-server:v2.4.2
9.访问登录验证
浏览器地址栏输入如下信息,能正常进入页面即正常。
ip:8848/nacos
六、docker安装rabbitmq
1.拉取镜像
# 查看rabbitmq所有镜像并拉取合适的镜像
[root@fyh_test ~]# docker search rabbitmq
[root@fyh_test ~]# docker pull rabbitmq
2.启动容器
[root@fyh_test ~]# docker run -d --hostname my-rabbit --name rabbit -p 15672:15672 -p 5673:5672 rabbitmq
3.查看已启动的容器
[root@fyh_test ~]# docker ps
4. 进入容器启动
[root@fyh_test ~]# docker exec -it 862ae0d32642 /bin/bash
root@my-rabbit:/#
# 进入容器后继续执行命令启动
root@my-rabbit:/# rabbitmq-plugins enable rabbitmq_management
Enabling plugins on node rabbit@my-rabbit:
rabbitmq_management
The following plugins have been configured:
rabbitmq_management
rabbitmq_management_agent
rabbitmq_prometheus
rabbitmq_web_dispatch
Applying plugin configuration to rabbit@my-rabbit...
Plugin configuration unchanged.
root@my-rabbit:/#
5.退出容器尝试登录
浏览器地址栏输入:ip + 端口 登录测试
账号/密码:guest/guest