Docker常用的部署(Mysql | Nginx | RabbitMQ | Seata | ES)

1.部署MySQL 

docker run -d \
  --name mysql \
  -p 3306:3306 \
  -e TZ=Asia/Shanghai \
  -e MYSQL_ROOT_PASSWORD=123 \
  -v ./mysql/data:/var/lib/mysql \
  -v ./mysql/conf:/etc/mysql/conf.d \
  -v ./mysql/init:/docker-entrypoint-initdb.d \
  mysql

2.部署Nginx

docker run -d \
    --name nginx \
    -p 18080:18080 \
    -p 18081:18081 \
    -v /root/nginx/html:/usr/share/nginx/html \
    -v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \
    --network hm\
    nginx

4.部署rabbitMQ

docker run \
 -e RABBITMQ_DEFAULT_USER=itcast \
 -e RABBITMQ_DEFAULT_PASS=123321 \
 --name mq \
 --hostname mq1 \
 -p 15672:15672 \
 -p 5672:5672 \
 -d \
 rabbitmq:3-management

5.部署Seata

需要在seata文件夹中根据实际情况在application.yml中修改Mysql的配置 

部署命令(需要根据具体情况修改SEATA_IP为自己的虚拟机IP地址,network为所连接的网络)

docker run --name seata \
-p 8099:8099 \
-p 7099:7099 \
-e SEATA_IP=192.168.92.136 \
-v ./seata:/seata-server/resources \
--privileged=true \
--network hm-net \
-d \
seataio/seata-server:1.5.2

6.部署MongoDB

## 通过docker安装MongoDB

~~~shell
#拉取镜像
docker pull mongo:4.0.3

#创建容器
docker create --name mongodb-server -p 27017:27017 -v mongodb-data:/data/db mongo:4.0.3 --auth

#启动容器
docker start mongodb-server

#进入容器
docker exec -it mongodb-server /bin/bash

#进入admin数据库
mongo
use admin

#添加管理员,其拥有管理用户和角色的权限
db.createUser({ user: 'root', pwd: 'root', roles: [ { role: "root", db: "admin" } ] })
#退出后进行认证

#进行认证
mongo -u "root" -p "root" --authenticationDatabase "admin"

#通过admin添加普通用户
use admin
db.createUser({ user: 'house', pwd: 'oudqBFGmGY8pU6WS', roles: [ { role: "readWrite", db: "house" } ] });

#通过tanhua用户登录进行测试
mongo -u "house" -p "oudqBFGmGY8pU6WS" --authenticationDatabase "admin"

#发现可以正常进入控制台进行操作

7.部署ElasticSearch和kibana、Ik分词器

要将ElasticSearch和kibana两个放入一个网络容器中

ElasticSearch:

docker run -d \
    --name es \
    -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" \
    -e "discovery.type=single-node" \
    -v es-data:/usr/share/elasticsearch/data \
    -v es-plugins:/usr/share/elasticsearch/plugins \
    --privileged \
    --network es-net \
    -p 9200:9200 \
    -p 9300:9300 \
elasticsearch:7.12.1

 kibana:

docker run -d \
--name kibana \
-e ELASTICSEARCH_HOSTS=http://es:9200 \
--network=es-net \
-p 5601:5601 \
kibana:7.12.1

IK分词器

进入容器内部:

docker exec -it elasticsearch /bin/bash

在线下载并安装

./bin/elasticsearch-plugin install
https://github.com/medcl/elasticsearch-analysis-
ik/releases/download/v7.12.1/elasticsearch-analysis-ik-7.12.1.zip
 

 退出

exit

 重启后生效

docker restart elasticsearch

 

相关推荐

  1. docker常用命令

    2024-05-25 21:42:36       26 阅读
  2. Doccker常用命令

    2024-05-25 21:42:36       39 阅读
  3. Docker常用命令

    2024-05-25 21:42:36       15 阅读
  4. docker安装常用中间件脚本

    2024-05-25 21:42:36       30 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-25 21:42:36       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-25 21:42:36       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-25 21:42:36       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-25 21:42:36       20 阅读

热门阅读

  1. 行为型设计模式

    2024-05-25 21:42:36       12 阅读
  2. RabbitMQ统一消息处理

    2024-05-25 21:42:36       10 阅读
  3. golang信号通知 signal.Notify NotifyContext完整示例

    2024-05-25 21:42:36       9 阅读
  4. sql日期函数统计日月年订单数

    2024-05-25 21:42:36       10 阅读
  5. MySQL之架构设计与历史(六)

    2024-05-25 21:42:36       8 阅读
  6. [数据集][图像分类]车辆分类数据集1600张10类别

    2024-05-25 21:42:36       13 阅读
  7. HTML5 本地存储与应用缓存

    2024-05-25 21:42:36       11 阅读
  8. memcpy的使⽤和模拟实现

    2024-05-25 21:42:36       16 阅读
  9. 通关!游戏设计之道Day14

    2024-05-25 21:42:36       13 阅读
  10. python 多线程处理图片

    2024-05-25 21:42:36       13 阅读
  11. unity 制作app实现底部导航栏和顶部状态栏

    2024-05-25 21:42:36       13 阅读