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

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
想把 Ja va 微服务稳稳当当地部署在 CentOS 服务器上?这事儿说复杂也复杂,说简单也简单。关键在于把环境、部署方式和运维要点这三块基石打牢。下面这份实操指南,就为你一步步拆解清楚。
一 环境准备与基础组件
万事开头难,先把地基打好。这一步的核心就四件事:装好Ja va、规划好目录、按需部署中间件、最后别忘了给防火墙打个招呼。
- 安装 JDK 8(OpenJDK):最直接的方式,一条命令搞定:
sudo yum install -y ja va-1.8.0-openjdk-devel。装完后,用ja va -version和ja 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 ... &配合jps、kill命令也无可厚非。 - 配置与密钥:数据库连接、消息队列地址、注册中心密码这些敏感信息,绝对不能硬编码在代码里。必须放到外部的配置文件、环境变量,或者更专业的密钥管理系统(如 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-develja va -version && ja vac -version
- 以普通用户部署并后台运行(示例)
su - ja vaappcd /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 & - 查看进程:
jps或ps -ef | grep ja va
- 停止服务(先查 PID 再 kill)
jps获取进程号 PIDkill -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-reloadsudo systemctl enable --now order-servicesudo systemctl status order-service- 查看日志:
journalctl -u order-service -f
- 内容示例:
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
如何优化Apache2响应速度
Apache2响应速度优化实操指南 想让你的Apache2服务器跑得更快?这事儿其实有章可循。下面这份实操指南,将从基础到进阶,帮你系统地提升响应速度。记住,所有优化都建立在不变动核心业务逻辑和架构的前提下。 一 基础与系统层面优化 优化得从地基开始。系统层面的几个关键设置,往往能以小成本换来大收益
git多人协作的工作流程【汇总】
多人协作必须禁用直接 push 到 main 分支:PR MR 流程是保障代码质量、自动化测试与冲突预判的核心机制;最佳实践包括语义化分支命名、启用分支保护规则,并规范 rebase 与 merge 的使用场景。 多人协作时,为什么禁止直接 push 到 main 分支? 直接向主分支推送代码,表面
CentOS上如何升级PHPStorm到最新版本
在 CentOS 上升级 PhpStorm 的可选方案 说到在 CentOS 上升级 PhpStorm,其实路径很清晰。核心原则是:优先使用内置更新或 JetBrains Toolbox App 这类自动管理工具,其次才是手动下载安装包覆盖升级。下面,就按推荐顺序,把每种方式的操作步骤和关键要点给你
Atom如何设置自动保存?Atom自动保存功能开启教程
Atom如何设置自动保存?Atom自动保存功能开启教程 如果你还在为Atom的自动保存功能头疼,那很可能踩中了几个常见的“坑”。从1 27版本开始,autosa ve功能已经作为核心特性内置,不再依赖插件。但问题也随之而来:为什么设置了却不见效?答案往往藏在版本、配置层级,或者那些本该被清理的旧插件
如何在CentOS上备份PHPStorm的配置文件
在 CentOS 上备份 PhpStorm 配置文件:完整指南与最佳实践 一、备份前的准备工作 在开始备份 PhpStorm 配置之前,充分的准备工作至关重要。这能有效保障备份数据的完整性与安全性,避免因操作不当导致配置丢失或损坏。 彻底关闭 PhpStorm 应用程序:这是首要且必须的步骤。确保
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

