docker-compose.yml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491
  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.5.3
  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.5.3
  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. ruoyi-monitor:
  131. image: ruoyi/ruoyi-monitor:2.5.3
  132. container_name: ruoyi-monitor
  133. environment:
  134. # 时区上海
  135. TZ: Asia/Shanghai
  136. ports:
  137. - "9100:9100"
  138. volumes:
  139. # 配置文件
  140. - /docker/ruoyi-monitor/logs/:/ruoyi/monitor/logs
  141. # skywalking 探针
  142. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  143. privileged: true
  144. network_mode: "host"
  145. ruoyi-snailjob-server:
  146. image: ruoyi/ruoyi-snailjob-server:2.5.3
  147. container_name: ruoyi-snailjob-server
  148. environment:
  149. # 时区上海
  150. TZ: Asia/Shanghai
  151. ports:
  152. - "8800:8800"
  153. - "17888:17888"
  154. volumes:
  155. - /docker/snailjob/logs/:/ruoyi/snailjob/logs
  156. privileged: true
  157. network_mode: "host"
  158. ruoyi-gateway:
  159. image: ruoyi/ruoyi-gateway:2.5.3
  160. container_name: ruoyi-gateway
  161. environment:
  162. # 时区上海
  163. TZ: Asia/Shanghai
  164. ports:
  165. - "8080:8080"
  166. volumes:
  167. # 配置文件
  168. - /docker/ruoyi-gateway/logs/:/ruoyi/gateway/logs
  169. # skywalking 探针
  170. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  171. privileged: true
  172. network_mode: "host"
  173. ruoyi-auth:
  174. image: ruoyi/ruoyi-auth:2.5.3
  175. container_name: ruoyi-auth
  176. environment:
  177. # 时区上海
  178. TZ: Asia/Shanghai
  179. ports:
  180. - "9210:9210"
  181. volumes:
  182. # 配置文件
  183. - /docker/ruoyi-auth/logs/:/ruoyi/auth/logs
  184. # skywalking 探针
  185. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  186. privileged: true
  187. network_mode: "host"
  188. ruoyi-system:
  189. image: ruoyi/ruoyi-system:2.5.3
  190. container_name: ruoyi-system
  191. environment:
  192. # 时区上海
  193. TZ: Asia/Shanghai
  194. ports:
  195. - "9201:9201"
  196. volumes:
  197. # 配置文件
  198. - /docker/ruoyi-system/logs/:/ruoyi/system/logs
  199. # skywalking 探针
  200. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  201. privileged: true
  202. network_mode: "host"
  203. ruoyi-gen:
  204. image: ruoyi/ruoyi-gen:2.5.3
  205. container_name: ruoyi-gen
  206. environment:
  207. # 时区上海
  208. TZ: Asia/Shanghai
  209. ports:
  210. - "9202:9202"
  211. volumes:
  212. # 配置文件
  213. - /docker/ruoyi-gen/logs/:/ruoyi/gen/logs
  214. # skywalking 探针
  215. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  216. privileged: true
  217. network_mode: "host"
  218. ruoyi-job:
  219. image: ruoyi/ruoyi-job:2.5.3
  220. container_name: ruoyi-job
  221. environment:
  222. # 时区上海
  223. TZ: Asia/Shanghai
  224. SERVER_PORT: 9203
  225. SNAIL_PORT: 19203
  226. ports:
  227. - "9203:9203"
  228. volumes:
  229. # 配置文件
  230. - /docker/ruoyi-job/logs/:/ruoyi/job/logs
  231. # skywalking 探针
  232. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  233. privileged: true
  234. network_mode: "host"
  235. ruoyi-resource:
  236. image: ruoyi/ruoyi-resource:2.5.3
  237. container_name: ruoyi-resource
  238. environment:
  239. # 时区上海
  240. TZ: Asia/Shanghai
  241. ports:
  242. - "9204:9204"
  243. volumes:
  244. # 配置文件
  245. - /docker/ruoyi-resource/logs/:/ruoyi/resource/logs
  246. # skywalking 探针
  247. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  248. privileged: true
  249. network_mode: "host"
  250. ruoyi-workflow:
  251. image: ruoyi/ruoyi-workflow:2.5.3
  252. container_name: ruoyi-workflow
  253. environment:
  254. # 时区上海
  255. TZ: Asia/Shanghai
  256. ports:
  257. - "9205:9205"
  258. volumes:
  259. # 配置文件
  260. - /docker/ruoyi-workflow/logs/:/ruoyi/workflow/logs
  261. # skywalking 探针
  262. - /docker/skywalking/agent/:/ruoyi/skywalking/agent
  263. privileged: true
  264. network_mode: "host"
  265. #################################################################################################
  266. #################################### 以下为扩展根据需求搭建 #########################################
  267. #################################################################################################
  268. elasticsearch:
  269. image: elasticsearch:7.17.6
  270. container_name: elasticsearch
  271. ports:
  272. - "9200:9200"
  273. - "9300:9300"
  274. environment:
  275. # 时区上海
  276. TZ: Asia/Shanghai
  277. # 设置集群名称
  278. cluster.name: elasticsearch
  279. # 以单一节点模式启动
  280. discovery.type: single-node
  281. ES_JAVA_OPTS: "-Xms512m -Xmx512m"
  282. volumes:
  283. - /docker/elk/elasticsearch/plugins:/usr/share/elasticsearch/plugins
  284. - /docker/elk/elasticsearch/data:/usr/share/elasticsearch/data
  285. - /docker/elk/elasticsearch/logs:/usr/share/elasticsearch/logs
  286. network_mode: "host"
  287. kibana:
  288. image: kibana:7.17.6
  289. container_name: kibana
  290. ports:
  291. - "5601:5601"
  292. depends_on:
  293. # kibana在elasticsearch启动之后再启动
  294. - elasticsearch
  295. environment:
  296. # 时区上海
  297. TZ: Asia/Shanghai
  298. #设置系统语言文中文
  299. I18N_LOCALE: zh-CN
  300. # 访问域名
  301. # SERVER_PUBLICBASEURL: https://kibana.cloud.com
  302. volumes:
  303. - /docker/elk/kibana/config/kibana.yml:/usr/share/kibana/config/kibana.yml
  304. network_mode: "host"
  305. logstash:
  306. image: logstash:7.17.6
  307. container_name: logstash
  308. ports:
  309. - "4560:4560"
  310. environment:
  311. # 时区上海
  312. TZ: Asia/Shanghai
  313. volumes:
  314. - /docker/elk/logstash/pipeline/logstash.conf:/usr/share/logstash/pipeline/logstash.conf
  315. - /docker/elk/logstash/config/logstash.yml:/usr/share/logstash/config/logstash.yml
  316. depends_on:
  317. - elasticsearch
  318. network_mode: "host"
  319. rmqnamesrv:
  320. image: apache/rocketmq:5.2.0
  321. container_name: rmqnamesrv
  322. ports:
  323. - "9876:9876"
  324. environment:
  325. JAVA_OPT: -server -Xms512m -Xmx512m
  326. command: sh mqnamesrv
  327. volumes:
  328. - /docker/rocketmq/namesrv/logs:/home/rocketmq/logs/rocketmqlogs
  329. network_mode: "host"
  330. rmqbroker1:
  331. image: apache/rocketmq:5.2.0
  332. container_name: rmqbroker1
  333. ports:
  334. - "10911:10911"
  335. - "10909:10909"
  336. - "10912:10912"
  337. environment:
  338. JAVA_OPT: -server -Xms512M -Xmx512M
  339. NAMESRV_ADDR: 127.0.0.1:9876
  340. # --enable-proxy 开启broker与proxy共用模式 生产部署建议将proxy单独部署
  341. command: sh mqbroker --enable-proxy -c /home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  342. depends_on:
  343. - rmqnamesrv
  344. volumes:
  345. - /docker/rocketmq/broker1/conf/broker.conf:/home/rocketmq/rocketmq-5.2.0/conf/broker.conf
  346. - /docker/rocketmq/broker1/logs:/home/rocketmq/logs/rocketmqlogs
  347. - /docker/rocketmq/broker1/store:/home/rocketmq/store
  348. privileged: true
  349. network_mode: "host"
  350. rmqconsole:
  351. image: apacherocketmq/rocketmq-dashboard:latest
  352. container_name: rmqconsole
  353. ports:
  354. - "19876:19876"
  355. environment:
  356. JAVA_OPTS: -Dserver.port=19876 -Drocketmq.namesrv.addr=127.0.0.1:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false
  357. depends_on:
  358. - rmqnamesrv
  359. network_mode: "host"
  360. rabbitmq:
  361. container_name: rabbitmq
  362. build:
  363. context: ./rabbitmq
  364. environment:
  365. RABBITMQ_DEFAULT_USER: ruoyi
  366. RABBITMQ_DEFAULT_PASS: ruoyi123
  367. ports:
  368. - "15672:15672" # 管理界面端口
  369. - "5672:5672" # api 端口
  370. volumes:
  371. - /docker/rabbitmq/log:/var/log/rabbitmq
  372. - /docker/rabbitmq/data:/var/lib/rabbitmq
  373. network_mode: "host"
  374. kafka:
  375. image: apache/kafka:3.9.1
  376. container_name: kafka
  377. ports:
  378. - "9092:9092"
  379. - "9093:9093"
  380. environment:
  381. KAFKA_NODE_ID: 1
  382. KAFKA_PROCESS_ROLES: broker,controller
  383. # 监听端口
  384. KAFKA_LISTENERS: PLAINTEXT://0.0.0.0:9092,CONTROLLER://0.0.0.0:9093
  385. # 实际访问ip 本地用 127 内网用 192 外网用 外网ip
  386. KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://192.168.31.165:9092
  387. KAFKA_CONTROLLER_QUORUM_VOTERS: 1@localhost:9093
  388. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT
  389. KAFKA_INTER_BROKER_LISTENER_NAME: PLAINTEXT
  390. KAFKA_CONTROLLER_LISTENER_NAMES: CONTROLLER
  391. KAFKA_LOG_DIRS: /var/lib/kafka/data
  392. KAFKA_AUTO_CREATE_TOPICS_ENABLE: "true"
  393. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
  394. KAFKA_LOG_RETENTION_HOURS: 168
  395. KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
  396. CLUSTER_ID: "Mk3OEYBSD34fcwNTJENDM2Qk" # 使用 kafka-storage.sh random-uuid 生成
  397. volumes:
  398. - /docker/kafka/data:/var/lib/kafka/data
  399. network_mode: "host"
  400. sky-oap:
  401. image: apache/skywalking-oap-server:9.7.0
  402. container_name: sky-oap
  403. ports:
  404. - "11800:11800"
  405. - "12800:12800"
  406. environment:
  407. JAVA_OPTS: -Xms1G -Xmx2G
  408. #记录数据的有效期,单位天
  409. SW_CORE_RECORD_DATA_TTL: 7
  410. #分析指标数据的有效期,单位天
  411. SW_CORE_METRICS_DATA_TTL: 7
  412. SW_STORAGE: elasticsearch
  413. SW_STORAGE_ES_CLUSTER_NODES: 127.0.0.1:9200
  414. TZ: Asia/Shanghai
  415. network_mode: "host"
  416. sky-ui:
  417. image: apache/skywalking-ui:9.7.0
  418. container_name: sky-ui
  419. ports:
  420. - "18080:18080"
  421. environment:
  422. SW_SERVER_PORT: 18080
  423. SW_OAP_ADDRESS: http://127.0.0.1:12800
  424. TZ: Asia/Shanghai
  425. depends_on:
  426. - sky-oap
  427. network_mode: "host"
  428. prometheus:
  429. image: prom/prometheus:v2.40.1
  430. container_name: prometheus
  431. ports:
  432. - "9090:9090"
  433. volumes:
  434. - /docker/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
  435. network_mode: "host"
  436. grafana:
  437. image: grafana/grafana:9.2.4
  438. container_name: grafana
  439. environment:
  440. TZ: Asia/Shanghai
  441. # 服务地址 用于指定外网ip或域名
  442. GF_SERVER_ROOT_URL: ""
  443. # admin 管理员密码
  444. GF_SECURITY_ADMIN_PASSWORD: 123456
  445. ports:
  446. - "3000:3000"
  447. volumes:
  448. - /docker/grafana/grafana.ini:/etc/grafana/grafana.ini
  449. - /docker/grafana:/var/lib/grafana
  450. network_mode: "host"
  451. shardingproxy:
  452. image: apache/shardingsphere-proxy:5.4.0
  453. container_name: shardingsphere-proxy
  454. command: server /data
  455. ports:
  456. - "3307:3307"
  457. volumes:
  458. - /docker/shardingproxy/conf:/opt/shardingsphere-proxy/conf
  459. - /docker/shardingproxy/ext-lib:/opt/shardingsphere-proxy/ext-lib
  460. environment:
  461. - JVM_OPTS="-Djava.awt.headless=true"
  462. network_mode: "host"