商城首页欢迎来到中国正版软件门户

您的位置:首页 >CentOS Java微服务如何搭建

CentOS Java微服务如何搭建

  发布于2026-04-23 阅读(0)

扫一扫,手机访问

在 CentOS 上搭建 Ja va 微服务的实操指南

CentOS Ja va微服务如何搭建

想把 Ja va 微服务稳稳当当地部署在 CentOS 服务器上?这事儿说复杂也复杂,说简单也简单。关键在于把环境、部署方式和运维要点这三块基石打牢。下面这份实操指南,就为你一步步拆解清楚。

一 环境准备与基础组件

万事开头难,先把地基打好。这一步的核心就四件事:装好Ja va、规划好目录、按需部署中间件、最后别忘了给防火墙打个招呼。

  • 安装 JDK 8(OpenJDK):最直接的方式,一条命令搞定:sudo yum install -y ja va-1.8.0-openjdk-devel。装完后,用 ja va -versionja vac -version 验明正身。如果团队规定必须用 Oracle JDK,那就得辛苦点,手动下载并配置好 JA VA_HOME 环境变量。
  • 创建运行用户与应用目录:直接用 root 跑应用是大忌。正确的做法是,创建一个专属用户,比如 ja vaapp,然后规划好目录结构。通常,/home/ja vaapp/soft 放安装包,/home/ja vaapp/app 放微服务的 JAR 包,再单独建个 /home/ja vaapp/app/logs 来统一管理日志,后期排查问题会清爽很多。
  • 基础中间件按需安装:微服务离不开各种中间件支撑。缓存和会话可以用 Redis 6.x;业务数据存 MySQL 5.7;如果选用 Dubbo 框架,就需要 Zookeeper 3.4.x 做注册中心;还有些传统项目可能需要 Tomcat 9 来部署 War 包。这里有个小提示:安装 Redis 或 Zookeeper 时,记得配置成系统服务(systemd unit),实现后台运行和开机自启,管理起来会方便得多。比如 Zookeeper,下载解压后,把 conf/zoo_sample.cfg 复制一份并重命名为 zoo.cfg,就能启动了。
  • 防火墙放行端口:应用启动后却访问不了?多半是防火墙的锅。记住这个命令模板,把其中的端口号换成你实际用的就行:firewall-cmd --add-port=8080/tcp --permanent && firewall-cmd --reload

二 两种常见微服务落地方式

环境就绪,接下来就是重头戏:如何把微服务跑起来。目前主流有两种架构风格,选择哪一种,得看你的技术栈和具体需求。

方式 A Spring Boot + Spring Cloud(内嵌容器,JAR 直跑)

这是目前最流行的“全家桶”方案,特点是开箱即用,服务治理组件丰富。

  • 构建:使用 Ma ven 或 Gradle 打包,得到一个包含所有依赖的“胖JAR”(fat-jar)。
  • 运行:运行方式很灵活。
    • 想快速调试?直接前台运行:ja va -jar app.jar
    • 正式部署必须后台常驻:nohup ja va -jar app.jar >/dev/null 2>&1 &
    • JVM 参数是性能稳定的关键,建议至少设置堆内存和元空间大小,例如:-Xms512m -Xmx512m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m。别忘了加上输出 GC 日志的参数,这可是线上排查内存问题的“救命稻草”。
  • 配置:别把配置写死在 JAR 包里。推荐使用外置的 application.yml,通过 --spring.config.location=... 参数指定路径。多环境(开发、测试、生产)配置,就用 application-{profile}.yml 来区分。
  • 进程与日志:运行后,用 jps 命令可以快速查看 Ja va 进程。日志务必统一输出到之前规划好的 /home/ja vaapp/app/logs/ 目录下,并配置好按天或按大小滚动,避免撑爆磁盘。
  • 服务治理:这才是 Spring Cloud 的精华。服务发现可以用 Eureka、Consul 或更流行的 Nacos;网关选型有 Spring Cloud Gateway 或 Zuul;配置中心可以用 Spring Cloud Config 或直接使用 Nacos 一站式解决。把这些组件搭起来,一个功能完整的微服务集群就有了雏形。

方式 B Spring Boot + Dubbo(RPC 框架)

如果你追求更高效、更直接的远程过程调用(RPC),那么 Dubbo 这套经典组合值得考虑。

  • 架构角色:先理解 Dubbo 的五个核心角色:服务提供者(Provider)、消费者(Consumer)、注册中心(Registry)、监控中心(Monitor)和运行容器(Container)。
  • 注册中心:Dubbo 官方推荐使用 Zookeeper。确保 Zookeeper 已安装并启动,用 ./zkServer.sh status 检查一下状态。
  • 工程结构:项目结构要规划好。通常需要一个独立的 API 模块,专门定义服务接口和数据传输对象(DTO)。然后,Provider 模块实现这些接口并暴露服务,Consumer 模块引用接口进行远程调用。这种分离保证了接口契约的清晰和双方依赖的明确。
  • 依赖示例:以 Dubbo 2.7.x 配合 Zookeeper 为例,核心依赖是 dubbo-spring-boot-starter:2.7.3 和对应的 Zookeeper 客户端依赖。
  • 部署与验证:将 Provider 和 Consumer 分别打包成 JAR,在 CentOS 上启动。观察 Zookeeper 的注册节点,以及服务调用时的日志,就能验证整个 RPC 链路是否通畅。

三 部署与运维要点

服务能跑起来只是第一步,要让它跑得稳、跑得久,还得在部署运维上下功夫。这几点是过来人总结的血泪经验。

  • 进程管理:别再用简单的 nohup 了。生产环境强烈推荐使用 systemd 来托管服务。它能帮你轻松实现开机自启、自动重启、日志统一收集和轮转。后文会给出具体的配置模板。当然,临时测试时用 nohup ... & 配合 jpskill 命令也无可厚非。
  • 配置与密钥:数据库连接、消息队列地址、注册中心密码这些敏感信息,绝对不能硬编码在代码里。必须放到外部的配置文件、环境变量,或者更专业的密钥管理系统(如 HashiCorp Vault、阿里云 KMS)中。不同环境(dev/test/prod)务必使用独立的配置 profile。
  • 日志与监控:日志是排查线上问题的唯一线索(很多时候)。必须规范日志目录,并配置合理的滚动策略。监控是系统的“心电图”,尽早接入 Prometheus + Grafana 这套组合,通过 Micrometer 或 Spring Boot Actuator 暴露指标,对核心业务逻辑做好埋点,才能做到心中有数,遇事不慌。
  • 网络与安全:安全无小事。服务器防火墙只开放必要的业务端口;对外提供的接口尽量启用 HTTPS/TLS;在网关层做好限流、熔断和鉴权;数据库和中间件一律使用权限最小化的账号进行连接。这些措施是守护系统安全的基本防线。

四 最小可用示例命令清单

理论说了这么多,不如动手敲一遍。下面这份命令清单,覆盖了从安装到运维的关键操作,你可以直接复制执行。

  • 安装 JDK 8
    • sudo yum install -y ja va-1.8.0-openjdk-devel
    • ja va -version && ja vac -version
  • 以普通用户部署并后台运行(示例)
    • su - ja vaapp
    • cd /home/ja vaapp/app/order-service
    • 前台试跑:ja va -jar order-service-0.0.1-SNAPSHOT.jar --spring.config.location=./application-prod.yml
    • 后台常驻:nohup ja va -Xms512m -Xmx512m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:./logs/gc.log -jar order-service-0.0.1-SNAPSHOT.jar --spring.config.location=./application-prod.yml >./logs/run.log 2>&1 &
    • 查看进程:jpsps -ef | grep ja va
  • 停止服务(先查 PID 再 kill)
    • jps 获取进程号 PID
    • kill -9 (生产建议优雅停机:kill 或调用 Actuator shutdown)
  • 防火墙放行示例端口
    • firewall-cmd --add-port=8080/tcp --permanent && firewall-cmd --reload
  • 使用 systemd 托管示例(创建文件:/etc/systemd/system/order-service.service)
    • 内容示例:
      [Unit]
      Description=Order Service
      After=network.target
      
      [Service]
      Type=simple
      User=ja vaapp
      WorkingDirectory=/home/ja vaapp/app/order-service
      ExecStart=/usr/bin/ja va -Xms512m -Xmx512m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -jar /home/ja vaapp/app/order-service/order-service-0.0.1-SNAPSHOT.jar --spring.config.location=./application-prod.yml
      SuccessExitStatus=143
      Restart=on-failure
      StandardOutput=journal
      StandardError=journal
      
      [Install]
      WantedBy=multi-user.target
    • 启用与启动:
      • sudo systemctl daemon-reload
      • sudo systemctl enable --now order-service
      • sudo systemctl status order-service
      • 查看日志:journalctl -u order-service -f
本文转载于:https://www.yisu.com/ask/66275341.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注