No Description

docker-compose.yml 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  1. version: '3'
  2. services:
  3. mysql:
  4. image: mysql:8.0.31
  5. container_name: mysql
  6. environment:
  7. # 时区上海
  8. TZ: Asia/Shanghai
  9. # root 密码
  10. MYSQL_ROOT_PASSWORD: ruoyi123
  11. # 初始化数据库
  12. MYSQL_DATABASE: ry-cloud
  13. ports:
  14. - "3306:3306"
  15. volumes:
  16. # 数据挂载
  17. - /docker/mysql/data/:/var/lib/mysql/
  18. # 配置挂载
  19. - /docker/mysql/conf/:/etc/mysql/conf.d/
  20. command:
  21. # 将mysql8.0默认密码策略 修改为 原先 策略 (mysql8.0对其默认策略做了更改 会导致密码无法匹配)
  22. --default-authentication-plugin=mysql_native_password
  23. --character-set-server=utf8mb4
  24. --collation-server=utf8mb4_general_ci
  25. --explicit_defaults_for_timestamp=true
  26. --lower_case_table_names=1
  27. privileged: true
  28. network_mode: "host"
  29. nacos:
  30. image: ruoyi/ruoyi-nacos:2.2.0
  31. container_name: nacos
  32. ports:
  33. - "8848:8848"
  34. - "9848:9848"
  35. - "9849:9849"
  36. environment:
  37. TZ: Asia/Shanghai
  38. JAVA_OPTS: "-Xms256m -Xmx512m"
  39. volumes:
  40. # 日志目录 注意集群模式下 日志目录不能一致 需要区分例如 nacos1 nacos2
  41. - /docker/nacos/logs/:/root/nacos/logs
  42. # 集群配置文件 集群所有nacos都必须使用此文件
  43. - /docker/nacos/conf/cluster.conf:/root/nacos/conf/cluster.conf
  44. network_mode: "host"
  45. redis:
  46. image: redis:6.2.12
  47. container_name: redis
  48. ports:
  49. - "6379:6379"
  50. environment:
  51. # 时区上海
  52. TZ: Asia/Shanghai
  53. volumes:
  54. # 配置文件
  55. - /docker/redis/conf:/redis/config
  56. # 数据文件
  57. - /docker/redis/data/:/redis/data/
  58. command: "redis-server /redis/config/redis.conf"
  59. privileged: true
  60. network_mode: "host"
  61. minio:
  62. image: minio/minio:RELEASE.2023-03-24T21-41-23Z
  63. container_name: minio
  64. ports:
  65. # api 端口
  66. - "9000:9000"
  67. # 控制台端口
  68. - "9001:9001"
  69. environment:
  70. # 时区上海
  71. TZ: Asia/Shanghai
  72. # 管理后台用户名
  73. MINIO_ROOT_USER: ruoyi
  74. # 管理后台密码,最小8个字符
  75. MINIO_ROOT_PASSWORD: ruoyi123
  76. # https需要指定域名
  77. #MINIO_SERVER_URL: "https://xxx.com:9000"
  78. #MINIO_BROWSER_REDIRECT_URL: "https://xxx.com:9001"
  79. # 开启压缩 on 开启 off 关闭
  80. MINIO_COMPRESS: "off"
  81. # 扩展名 .pdf,.doc 为空 所有类型均压缩
  82. MINIO_COMPRESS_EXTENSIONS: ""
  83. # mime 类型 application/pdf 为空 所有类型均压缩
  84. MINIO_COMPRESS_MIME_TYPES: ""
  85. volumes:
  86. # 映射当前目录下的data目录至容器内/data目录
  87. - /docker/minio/data:/data
  88. # 映射配置目录
  89. - /docker/minio/config:/root/.minio/
  90. command: server --address ':9000' --console-address ':9001' /data # 指定容器中的目录 /data
  91. privileged: true
  92. network_mode: "host"
  93. seata-server:
  94. image: ruoyi/ruoyi-seata-server:2.2.0
  95. container_name: seata-server
  96. ports:
  97. - "7091:7091"
  98. - "8091:8091"
  99. environment:
  100. TZ: Asia/Shanghai
  101. # 注意 此处ip如果是外网使用 要改为外网ip
  102. # SEATA_IP: 127.0.0.1
  103. SEATA_PORT: 8091
  104. volumes:
  105. - /docker/ruoyi-seata-server/logs/:/ruoyi/seata-server/logs
  106. # skywalking 探针
  107. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  108. privileged: true
  109. network_mode: "host"
  110. nginx-web:
  111. image: nginx:1.22.1
  112. container_name: nginx-web
  113. environment:
  114. # 时区上海
  115. TZ: Asia/Shanghai
  116. ports:
  117. - "80:80"
  118. - "443:443"
  119. volumes:
  120. # 证书映射
  121. - /docker/nginx/cert:/etc/nginx/cert
  122. # 配置文件映射
  123. - /docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
  124. # 页面目录
  125. - /docker/nginx/html:/usr/share/nginx/html
  126. # 日志目录
  127. - /docker/nginx/log:/var/log/nginx
  128. privileged: true
  129. network_mode: "host"
  130. sentinel:
  131. image: ruoyi/ruoyi-sentinel-dashboard:2.2.0
  132. container_name: sentinel
  133. environment:
  134. TZ: Asia/Shanghai
  135. ports:
  136. - "8718:8718"
  137. volumes:
  138. # 配置文件
  139. - /docker/ruoyi-sentinel-dashboard/logs/:/ruoyi/sentinel-dashboard/logs
  140. # skywalking 探针
  141. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  142. restart: always
  143. network_mode: "host"
  144. ruoyi-monitor:
  145. image: ruoyi/ruoyi-monitor:2.2.0
  146. container_name: ruoyi-monitor
  147. environment:
  148. # 时区上海
  149. TZ: Asia/Shanghai
  150. ports:
  151. - "9100:9100"
  152. volumes:
  153. # 配置文件
  154. - /docker/ruoyi-monitor/logs/:/ruoyi/monitor/logs
  155. # skywalking 探针
  156. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  157. privileged: true
  158. network_mode: "host"
  159. ruoyi-snailjob-server:
  160. image: ruoyi/ruoyi-snailjob-server:2.2.0
  161. container_name: ruoyi-snailjob-server
  162. environment:
  163. # 时区上海
  164. TZ: Asia/Shanghai
  165. ports:
  166. - "8800:8800"
  167. - "17888:17888"
  168. volumes:
  169. - /docker/snailjob/logs/:/ruoyi/snailjob/logs
  170. privileged: true
  171. network_mode: "host"
  172. ruoyi-gateway:
  173. image: ruoyi/ruoyi-gateway:2.2.0
  174. container_name: ruoyi-gateway
  175. environment:
  176. # 时区上海
  177. TZ: Asia/Shanghai
  178. ports:
  179. - "8080:8080"
  180. volumes:
  181. # 配置文件
  182. - /docker/ruoyi-gateway/logs/:/ruoyi/gateway/logs
  183. # skywalking 探针
  184. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  185. privileged: true
  186. network_mode: "host"
  187. ruoyi-auth:
  188. image: ruoyi/ruoyi-auth:2.2.0
  189. container_name: ruoyi-auth
  190. environment:
  191. # 时区上海
  192. TZ: Asia/Shanghai
  193. ports:
  194. - "9210:9210"
  195. volumes:
  196. # 配置文件
  197. - /docker/ruoyi-auth/logs/:/ruoyi/auth/logs
  198. # skywalking 探针
  199. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  200. privileged: true
  201. network_mode: "host"
  202. ruoyi-system:
  203. image: ruoyi/ruoyi-system:2.2.0
  204. container_name: ruoyi-system
  205. environment:
  206. # 时区上海
  207. TZ: Asia/Shanghai
  208. ports:
  209. - "9201:9201"
  210. volumes:
  211. # 配置文件
  212. - /docker/ruoyi-system/logs/:/ruoyi/system/logs
  213. # skywalking 探针
  214. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  215. privileged: true
  216. network_mode: "host"
  217. ruoyi-gen:
  218. image: ruoyi/ruoyi-gen:2.2.0
  219. container_name: ruoyi-gen
  220. environment:
  221. # 时区上海
  222. TZ: Asia/Shanghai
  223. ports:
  224. - "9202:9202"
  225. volumes:
  226. # 配置文件
  227. - /docker/ruoyi-gen/logs/:/ruoyi/gen/logs
  228. # skywalking 探针
  229. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  230. privileged: true
  231. network_mode: "host"
  232. ruoyi-job:
  233. image: ruoyi/ruoyi-job:2.2.0
  234. container_name: ruoyi-job
  235. environment:
  236. # 时区上海
  237. TZ: Asia/Shanghai
  238. ports:
  239. - "9203:9203"
  240. volumes:
  241. # 配置文件
  242. - /docker/ruoyi-job/logs/:/ruoyi/job/logs
  243. # skywalking 探针
  244. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  245. privileged: true
  246. network_mode: "host"
  247. ruoyi-resource:
  248. image: ruoyi/ruoyi-resource:2.2.0
  249. container_name: ruoyi-resource
  250. environment:
  251. # 时区上海
  252. TZ: Asia/Shanghai
  253. ports:
  254. - "9204:9204"
  255. volumes:
  256. # 配置文件
  257. - /docker/ruoyi-resource/logs/:/ruoyi/resource/logs
  258. # skywalking 探针
  259. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  260. privileged: true
  261. network_mode: "host"
  262. ruoyi-workflow:
  263. image: ruoyi/ruoyi-workflow:2.2.0
  264. container_name: ruoyi-workflow
  265. environment:
  266. # 时区上海
  267. TZ: Asia/Shanghai
  268. ports:
  269. - "9205:9205"
  270. volumes:
  271. # 配置文件
  272. - /docker/ruoyi-workflow/logs/:/ruoyi/workflow/logs
  273. # skywalking 探针
  274. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  275. privileged: true
  276. network_mode: "host"
  277. #################################################################################################
  278. #################################### 以下为扩展根据需求搭建 #########################################
  279. #################################################################################################
  280. elasticsearch:
  281. image: elasticsearch:7.17.6
  282. container_name: elasticsearch
  283. ports:
  284. - "9200:9200"
  285. - "9300:9300"
  286. environment:
  287. # 设置集群名称
  288. cluster.name: elasticsearch
  289. # 以单一节点模式启动
  290. discovery.type: single-node
  291. ES_JAVA_OPTS: "-Xms512m -Xmx512m"
  292. volumes:
  293. - /docker/elk/elasticsearch/plugins:/usr/share/elasticsearch/plugins
  294. - /docker/elk/elasticsearch/data:/usr/share/elasticsearch/data
  295. - /docker/elk/elasticsearch/logs:/usr/share/elasticsearch/logs
  296. network_mode: "host"
  297. kibana:
  298. image: kibana:7.17.6
  299. container_name: kibana
  300. ports:
  301. - "5601:5601"
  302. depends_on:
  303. # kibana在elasticsearch启动之后再启动
  304. - elasticsearch
  305. environment:
  306. #设置系统语言文中文
  307. I18N_LOCALE: zh-CN
  308. # 访问域名
  309. # SERVER_PUBLICBASEURL: https://kibana.cloud.com
  310. volumes:
  311. - /docker/elk/kibana/config/kibana.yml:/usr/share/kibana/config/kibana.yml
  312. network_mode: "host"
  313. logstash:
  314. image: logstash:7.17.6
  315. container_name: logstash
  316. ports:
  317. - "4560:4560"
  318. volumes:
  319. - /docker/elk/logstash/pipeline/logstash.conf:/usr/share/logstash/pipeline/logstash.conf
  320. - /docker/elk/logstash/config/logstash.yml:/usr/share/logstash/config/logstash.yml
  321. depends_on:
  322. - elasticsearch
  323. network_mode: "host"
  324. rmqnamesrv:
  325. image: apache/rocketmq:5.2.0
  326. container_name: rmqnamesrv
  327. ports:
  328. - "9876:9876"
  329. environment:
  330. JAVA_OPT: -server -Xms512m -Xmx512m
  331. command: sh mqnamesrv
  332. volumes:
  333. - /docker/rocketmq/namesrv/logs:/home/rocketmq/logs/rocketmqlogs
  334. network_mode: "host"
  335. rmqbroker1:
  336. image: apache/rocketmq:5.2.0
  337. container_name: rmqbroker1
  338. ports:
  339. - "10911:10911"
  340. - "10909:10909"
  341. - "10912:10912"
  342. environment:
  343. JAVA_OPT: -server -Xms512M -Xmx512M
  344. NAMESRV_ADDR: 127.0.0.1:9876
  345. # --enable-proxy 开启broker与proxy共用模式 生产部署建议将proxy单独部署
  346. command: sh mqbroker --enable-proxy -c /home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  347. depends_on:
  348. - rmqnamesrv
  349. volumes:
  350. - /docker/rocketmq/broker1/conf/broker.conf:/home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  351. - /docker/rocketmq/broker1/logs:/home/rocketmq/logs/rocketmqlogs
  352. - /docker/rocketmq/broker1/store:/home/rocketmq/store
  353. privileged: true
  354. network_mode: "host"
  355. rmqconsole:
  356. image: apacherocketmq/rocketmq-dashboard:latest
  357. container_name: rmqconsole
  358. ports:
  359. - "19876:19876"
  360. environment:
  361. JAVA_OPTS: -Dserver.port=19876 -Drocketmq.namesrv.addr=127.0.0.1:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false
  362. depends_on:
  363. - rmqnamesrv
  364. network_mode: "host"
  365. rabbitmq:
  366. image: rabbitmq:3.13.3
  367. container_name: rabbitmq
  368. build:
  369. context: ./rabbitmq
  370. environment:
  371. RABBITMQ_DEFAULT_USER: ruoyi
  372. RABBITMQ_DEFAULT_PASS: ruoyi123
  373. ports:
  374. - "15672:15672" # 管理界面端口
  375. - "5672:5672" # api 端口
  376. volumes:
  377. - /docker/rabbitmq/log:/var/log/rabbitmq
  378. - /docker/rabbitmq/data:/var/lib/rabbitmq
  379. network_mode: "host"
  380. zookeeper:
  381. image: 'bitnami/zookeeper:3.8.0'
  382. container_name: zookeeper
  383. ports:
  384. - "2181:2181"
  385. environment:
  386. TZ: Asia/Shanghai
  387. ALLOW_ANONYMOUS_LOGIN: "yes"
  388. ZOO_SERVER_ID: 1
  389. ZOO_PORT_NUMBER: 2181
  390. # 自带的控制台 一般用不上可自行开启
  391. ZOO_ENABLE_ADMIN_SERVER: "no"
  392. # 自带控制台的端口
  393. ZOO_ADMIN_SERVER_PORT_NUMBER: 8080
  394. network_mode: "host"
  395. kafka:
  396. image: 'bitnami/kafka:3.6.2'
  397. container_name: kafka
  398. ports:
  399. - "9092:9092"
  400. environment:
  401. TZ: Asia/Shanghai
  402. # 更多变量 查看文档 https://github.com/bitnami/bitnami-docker-kafka/blob/master/README.md
  403. KAFKA_BROKER_ID: 1
  404. # 监听端口
  405. KAFKA_CFG_LISTENERS: PLAINTEXT://:9092
  406. # 实际访问ip 本地用 127 内网用 192 外网用 外网ip
  407. KAFKA_CFG_ADVERTISED_LISTENERS: PLAINTEXT://192.168.31.165:9092
  408. KAFKA_CFG_ZOOKEEPER_CONNECT: 127.0.0.1:2181
  409. ALLOW_PLAINTEXT_LISTENER: "yes"
  410. volumes:
  411. - /docker/kafka/data:/bitnami/kafka/data
  412. depends_on:
  413. - zookeeper
  414. network_mode: "host"
  415. kafka-manager:
  416. image: sheepkiller/kafka-manager:latest
  417. container_name: kafka-manager
  418. ports:
  419. - "19092:19092"
  420. environment:
  421. ZK_HOSTS: 127.0.0.1:2181
  422. APPLICATION_SECRET: letmein
  423. KAFKA_MANAGER_USERNAME: ruoyi
  424. KAFKA_MANAGER_PASSWORD: ruoyi123
  425. KM_ARGS: -Dhttp.port=19092
  426. depends_on:
  427. - kafka
  428. network_mode: "host"
  429. sky-oap:
  430. image: apache/skywalking-oap-server:9.7.0
  431. container_name: sky-oap
  432. ports:
  433. - "11800:11800"
  434. - "12800:12800"
  435. environment:
  436. JAVA_OPTS: -Xms1G -Xmx2G
  437. #记录数据的有效期,单位天
  438. SW_CORE_RECORD_DATA_TTL: 7
  439. #分析指标数据的有效期,单位天
  440. SW_CORE_METRICS_DATA_TTL: 7
  441. SW_STORAGE: elasticsearch
  442. SW_STORAGE_ES_CLUSTER_NODES: 127.0.0.1:9200
  443. TZ: Asia/Shanghai
  444. network_mode: "host"
  445. sky-ui:
  446. image: apache/skywalking-ui:9.7.0
  447. container_name: sky-ui
  448. ports:
  449. - "18080:18080"
  450. environment:
  451. SW_SERVER_PORT: 18080
  452. SW_OAP_ADDRESS: http://127.0.0.1:12800
  453. TZ: Asia/Shanghai
  454. depends_on:
  455. - sky-oap
  456. network_mode: "host"
  457. prometheus:
  458. image: prom/prometheus:v2.40.1
  459. container_name: prometheus
  460. ports:
  461. - "9090:9090"
  462. volumes:
  463. - /docker/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
  464. network_mode: "host"
  465. grafana:
  466. image: grafana/grafana:9.2.4
  467. container_name: grafana
  468. environment:
  469. TZ: Asia/Shanghai
  470. # 服务地址 用于指定外网ip或域名
  471. GF_SERVER_ROOT_URL: ""
  472. # admin 管理员密码
  473. GF_SECURITY_ADMIN_PASSWORD: 123456
  474. ports:
  475. - "3000:3000"
  476. volumes:
  477. - /docker/grafana/grafana.ini:/etc/grafana/grafana.ini
  478. - /docker/grafana:/var/lib/grafana
  479. network_mode: "host"
  480. shardingproxy:
  481. image: apache/shardingsphere-proxy:5.4.0
  482. container_name: shardingsphere-proxy
  483. command: server /data
  484. ports:
  485. - "3307:3307"
  486. volumes:
  487. - /docker/shardingproxy/conf:/opt/shardingsphere-proxy/conf
  488. - /docker/shardingproxy/ext-lib:/opt/shardingsphere-proxy/ext-lib
  489. environment:
  490. - JVM_OPTS="-Djava.awt.headless=true"
  491. network_mode: "host"