docker-compose.yml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. services:
  2. mysql:
  3. image: mysql:8.0.42
  4. container_name: mysql
  5. environment:
  6. # 时区上海
  7. TZ: Asia/Shanghai
  8. # root 密码
  9. MYSQL_ROOT_PASSWORD: ruoyi123
  10. # 初始化数据库
  11. MYSQL_DATABASE: ry-cloud
  12. ports:
  13. - "3306:3306"
  14. volumes:
  15. # 数据挂载
  16. - /docker/mysql/data/:/var/lib/mysql/
  17. # 配置挂载
  18. - /docker/mysql/conf/:/etc/mysql/conf.d/
  19. command:
  20. # 将mysql8.0默认密码策略 修改为 原先 策略 (mysql8.0对其默认策略做了更改 会导致密码无法匹配)
  21. --default-authentication-plugin=mysql_native_password
  22. --character-set-server=utf8mb4
  23. --collation-server=utf8mb4_general_ci
  24. --explicit_defaults_for_timestamp=true
  25. --lower_case_table_names=1
  26. privileged: true
  27. network_mode: "host"
  28. nacos:
  29. image: ruoyi/ruoyi-nacos:2.4.1
  30. container_name: nacos
  31. ports:
  32. - "8848:8848"
  33. - "9848:9848"
  34. - "9849:9849"
  35. environment:
  36. TZ: Asia/Shanghai
  37. JAVA_OPTS: "-Xms256m -Xmx512m"
  38. volumes:
  39. # 日志目录 注意集群模式下 日志目录不能一致 需要区分例如 nacos1 nacos2
  40. - /docker/nacos/logs/:/root/nacos/logs
  41. # 集群配置文件 集群所有nacos都必须使用此文件
  42. - /docker/nacos/conf/cluster.conf:/root/nacos/conf/cluster.conf
  43. network_mode: "host"
  44. redis:
  45. image: redis:7.2.8
  46. container_name: redis
  47. ports:
  48. - "6379:6379"
  49. environment:
  50. # 时区上海
  51. TZ: Asia/Shanghai
  52. volumes:
  53. # 配置文件
  54. - /docker/redis/conf:/redis/config
  55. # 数据文件
  56. - /docker/redis/data/:/redis/data/
  57. command: "redis-server /redis/config/redis.conf"
  58. privileged: true
  59. network_mode: "host"
  60. minio:
  61. # minio 最后一个未阉割版本 不能再进行升级 在往上的版本功能被阉割
  62. image: minio/minio:RELEASE.2025-04-22T22-12-26Z
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  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.4.1
  234. container_name: ruoyi-job
  235. environment:
  236. # 时区上海
  237. TZ: Asia/Shanghai
  238. SERVER_PORT: 9203
  239. SNAIL_PORT: 19203
  240. ports:
  241. - "9203:9203"
  242. volumes:
  243. # 配置文件
  244. - /docker/ruoyi-job/logs/:/ruoyi/job/logs
  245. # skywalking 探针
  246. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  247. privileged: true
  248. network_mode: "host"
  249. ruoyi-resource:
  250. image: ruoyi/ruoyi-resource:2.4.1
  251. container_name: ruoyi-resource
  252. environment:
  253. # 时区上海
  254. TZ: Asia/Shanghai
  255. ports:
  256. - "9204:9204"
  257. volumes:
  258. # 配置文件
  259. - /docker/ruoyi-resource/logs/:/ruoyi/resource/logs
  260. # skywalking 探针
  261. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  262. privileged: true
  263. network_mode: "host"
  264. ruoyi-workflow:
  265. image: ruoyi/ruoyi-workflow:2.4.1
  266. container_name: ruoyi-workflow
  267. environment:
  268. # 时区上海
  269. TZ: Asia/Shanghai
  270. ports:
  271. - "9205:9205"
  272. volumes:
  273. # 配置文件
  274. - /docker/ruoyi-workflow/logs/:/ruoyi/workflow/logs
  275. # skywalking 探针
  276. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  277. privileged: true
  278. network_mode: "host"
  279. #################################################################################################
  280. #################################### 以下为扩展根据需求搭建 #########################################
  281. #################################################################################################
  282. elasticsearch:
  283. image: elasticsearch:7.17.6
  284. container_name: elasticsearch
  285. ports:
  286. - "9200:9200"
  287. - "9300:9300"
  288. environment:
  289. # 设置集群名称
  290. cluster.name: elasticsearch
  291. # 以单一节点模式启动
  292. discovery.type: single-node
  293. ES_JAVA_OPTS: "-Xms512m -Xmx512m"
  294. volumes:
  295. - /docker/elk/elasticsearch/plugins:/usr/share/elasticsearch/plugins
  296. - /docker/elk/elasticsearch/data:/usr/share/elasticsearch/data
  297. - /docker/elk/elasticsearch/logs:/usr/share/elasticsearch/logs
  298. network_mode: "host"
  299. kibana:
  300. image: kibana:7.17.6
  301. container_name: kibana
  302. ports:
  303. - "5601:5601"
  304. depends_on:
  305. # kibana在elasticsearch启动之后再启动
  306. - elasticsearch
  307. environment:
  308. #设置系统语言文中文
  309. I18N_LOCALE: zh-CN
  310. # 访问域名
  311. # SERVER_PUBLICBASEURL: https://kibana.cloud.com
  312. volumes:
  313. - /docker/elk/kibana/config/kibana.yml:/usr/share/kibana/config/kibana.yml
  314. network_mode: "host"
  315. logstash:
  316. image: logstash:7.17.6
  317. container_name: logstash
  318. ports:
  319. - "4560:4560"
  320. volumes:
  321. - /docker/elk/logstash/pipeline/logstash.conf:/usr/share/logstash/pipeline/logstash.conf
  322. - /docker/elk/logstash/config/logstash.yml:/usr/share/logstash/config/logstash.yml
  323. depends_on:
  324. - elasticsearch
  325. network_mode: "host"
  326. rmqnamesrv:
  327. image: apache/rocketmq:5.2.0
  328. container_name: rmqnamesrv
  329. ports:
  330. - "9876:9876"
  331. environment:
  332. JAVA_OPT: -server -Xms512m -Xmx512m
  333. command: sh mqnamesrv
  334. volumes:
  335. - /docker/rocketmq/namesrv/logs:/home/rocketmq/logs/rocketmqlogs
  336. network_mode: "host"
  337. rmqbroker1:
  338. image: apache/rocketmq:5.2.0
  339. container_name: rmqbroker1
  340. ports:
  341. - "10911:10911"
  342. - "10909:10909"
  343. - "10912:10912"
  344. environment:
  345. JAVA_OPT: -server -Xms512M -Xmx512M
  346. NAMESRV_ADDR: 127.0.0.1:9876
  347. # --enable-proxy 开启broker与proxy共用模式 生产部署建议将proxy单独部署
  348. command: sh mqbroker --enable-proxy -c /home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  349. depends_on:
  350. - rmqnamesrv
  351. volumes:
  352. - /docker/rocketmq/broker1/conf/broker.conf:/home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  353. - /docker/rocketmq/broker1/logs:/home/rocketmq/logs/rocketmqlogs
  354. - /docker/rocketmq/broker1/store:/home/rocketmq/store
  355. privileged: true
  356. network_mode: "host"
  357. rmqconsole:
  358. image: apacherocketmq/rocketmq-dashboard:latest
  359. container_name: rmqconsole
  360. ports:
  361. - "19876:19876"
  362. environment:
  363. JAVA_OPTS: -Dserver.port=19876 -Drocketmq.namesrv.addr=127.0.0.1:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false
  364. depends_on:
  365. - rmqnamesrv
  366. network_mode: "host"
  367. rabbitmq:
  368. container_name: rabbitmq
  369. build:
  370. context: ./rabbitmq
  371. environment:
  372. RABBITMQ_DEFAULT_USER: ruoyi
  373. RABBITMQ_DEFAULT_PASS: ruoyi123
  374. ports:
  375. - "15672:15672" # 管理界面端口
  376. - "5672:5672" # api 端口
  377. volumes:
  378. - /docker/rabbitmq/log:/var/log/rabbitmq
  379. - /docker/rabbitmq/data:/var/lib/rabbitmq
  380. network_mode: "host"
  381. zookeeper:
  382. image: 'bitnami/zookeeper:3.8.0'
  383. container_name: zookeeper
  384. ports:
  385. - "2181:2181"
  386. environment:
  387. TZ: Asia/Shanghai
  388. ALLOW_ANONYMOUS_LOGIN: "yes"
  389. ZOO_SERVER_ID: 1
  390. ZOO_PORT_NUMBER: 2181
  391. # 自带的控制台 一般用不上可自行开启
  392. ZOO_ENABLE_ADMIN_SERVER: "no"
  393. # 自带控制台的端口
  394. ZOO_ADMIN_SERVER_PORT_NUMBER: 8080
  395. network_mode: "host"
  396. kafka:
  397. image: 'bitnami/kafka:3.6.2'
  398. container_name: kafka
  399. ports:
  400. - "9092:9092"
  401. environment:
  402. TZ: Asia/Shanghai
  403. # 更多变量 查看文档 https://github.com/bitnami/bitnami-docker-kafka/blob/master/README.md
  404. KAFKA_BROKER_ID: 1
  405. # 监听端口
  406. KAFKA_CFG_LISTENERS: PLAINTEXT://:9092
  407. # 实际访问ip 本地用 127 内网用 192 外网用 外网ip
  408. KAFKA_CFG_ADVERTISED_LISTENERS: PLAINTEXT://192.168.31.165:9092
  409. KAFKA_CFG_ZOOKEEPER_CONNECT: 127.0.0.1:2181
  410. ALLOW_PLAINTEXT_LISTENER: "yes"
  411. volumes:
  412. - /docker/kafka/data:/bitnami/kafka/data
  413. depends_on:
  414. - zookeeper
  415. network_mode: "host"
  416. kafka-manager:
  417. image: sheepkiller/kafka-manager:latest
  418. container_name: kafka-manager
  419. ports:
  420. - "19092:19092"
  421. environment:
  422. ZK_HOSTS: 127.0.0.1:2181
  423. APPLICATION_SECRET: letmein
  424. KAFKA_MANAGER_USERNAME: ruoyi
  425. KAFKA_MANAGER_PASSWORD: ruoyi123
  426. KM_ARGS: -Dhttp.port=19092
  427. depends_on:
  428. - kafka
  429. network_mode: "host"
  430. sky-oap:
  431. image: apache/skywalking-oap-server:9.7.0
  432. container_name: sky-oap
  433. ports:
  434. - "11800:11800"
  435. - "12800:12800"
  436. environment:
  437. JAVA_OPTS: -Xms1G -Xmx2G
  438. #记录数据的有效期,单位天
  439. SW_CORE_RECORD_DATA_TTL: 7
  440. #分析指标数据的有效期,单位天
  441. SW_CORE_METRICS_DATA_TTL: 7
  442. SW_STORAGE: elasticsearch
  443. SW_STORAGE_ES_CLUSTER_NODES: 127.0.0.1:9200
  444. TZ: Asia/Shanghai
  445. network_mode: "host"
  446. sky-ui:
  447. image: apache/skywalking-ui:9.7.0
  448. container_name: sky-ui
  449. ports:
  450. - "18080:18080"
  451. environment:
  452. SW_SERVER_PORT: 18080
  453. SW_OAP_ADDRESS: http://127.0.0.1:12800
  454. TZ: Asia/Shanghai
  455. depends_on:
  456. - sky-oap
  457. network_mode: "host"
  458. prometheus:
  459. image: prom/prometheus:v2.40.1
  460. container_name: prometheus
  461. ports:
  462. - "9090:9090"
  463. volumes:
  464. - /docker/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
  465. network_mode: "host"
  466. grafana:
  467. image: grafana/grafana:9.2.4
  468. container_name: grafana
  469. environment:
  470. TZ: Asia/Shanghai
  471. # 服务地址 用于指定外网ip或域名
  472. GF_SERVER_ROOT_URL: ""
  473. # admin 管理员密码
  474. GF_SECURITY_ADMIN_PASSWORD: 123456
  475. ports:
  476. - "3000:3000"
  477. volumes:
  478. - /docker/grafana/grafana.ini:/etc/grafana/grafana.ini
  479. - /docker/grafana:/var/lib/grafana
  480. network_mode: "host"
  481. shardingproxy:
  482. image: apache/shardingsphere-proxy:5.4.0
  483. container_name: shardingsphere-proxy
  484. command: server /data
  485. ports:
  486. - "3307:3307"
  487. volumes:
  488. - /docker/shardingproxy/conf:/opt/shardingsphere-proxy/conf
  489. - /docker/shardingproxy/ext-lib:/opt/shardingsphere-proxy/ext-lib
  490. environment:
  491. - JVM_OPTS="-Djava.awt.headless=true"
  492. network_mode: "host"