目录

黑马头条_SpringCloud项目阶段一环境搭建Mac版本

黑马头条_SpringCloud项目阶段一:环境搭建(Mac版本)

前言:

本文章使用的环境介绍:

本地系统:MacBoot M4

内存:24G

远程系统:阿里云云服务器Ubuntu24

内存:2G

后端代码仓库地址:

版本: 68d8d89b533b539027d63336cb1f077cfe8e3c53

Nacos注册中心

安装目标:阿里云云服务器

安装方式:docker

# 下载镜像
docker pull nacos/nacos-server:1.2.0
# 运行镜像
docker run --env MODE=standalone --name nacos --restart=always  -d -p 8848:8848 nacos/nacos-server:1.2.0
# 运行地址
http://varin.cn:8848/nacos

https://i-blog.csdnimg.cn/img_convert/c063011038a9c74f0180c4e8e398e332.png

一、命令整体功能

通过 Docker 拉取 nacos/nacos-server:1.2.0 镜像(若本地未缓存),并以独立模式(standalone) 启动一个名为 nacos 的容器,同时配置容器自动重启、端口映射,确保 Nacos 服务可外部访问且稳定运行。

二、参数逐段解析

命令片段核心作用详细说明
docker runDocker 核心指令用于“创建并启动一个 Docker 容器”的基础命令(若镜像本地不存在,会自动从 Docker Hub 拉取)。
--env MODE=standalone设置环境变量- --env(可简写为 -e):用于向容器内部传递环境变量,影响应用运行配置; - MODE=standalone:指定 Nacos 的运行模式为独立模式(单机模式),适合开发、测试场景; (补充:Nacos 还有 cluster 集群模式,需额外配置数据库、节点信息,用于生产环境)。
--name nacos命名容器给启动的容器指定一个唯一名称 nacos,后续操作(如停止、重启、进入容器)可直接用该名称,无需记复杂的容器 ID(例:docker stop nacos)。
--restart=always配置容器重启策略定义容器退出后的重启规则: - always:无论容器因何种原因退出(包括手动停止后重启 Docker 服务),都会自动重启; (其他常见策略:on-failure 仅故障退出时重启、no 不自动重启)。
-d后台运行容器全称 --detach,让容器在“后台(守护进程模式)”运行,不会占用当前终端窗口(若不加 -d,终端会直接输出 Nacos 的日志,关闭终端则容器停止)。
-p 8848:8848端口映射- -p:用于将“宿主机端口”与“容器内部端口”绑定,格式为 宿主机端口:容器内部端口; - 左侧 8848:宿主机(即你运行 Docker 的机器)的端口,外部通过该端口访问 Nacos; - 右侧 8848:Nacos 容器内部的默认服务端口(Nacos 官方默认端口,不可随意修改容器内端口,除非通过环境变量自定义); (例:若宿主机 8848 端口已被占用,可改为 8849:8848,外部访问时用 http://宿主机IP:8849)。
nacos/nacos-server:1.2.0指定镜像- nacos/nacos-server:Docker Hub 上的 Nacos 官方镜像名称; - :1.2.0:指定镜像的版本号(固定使用 1.2.0 版本,避免因拉取最新版导致兼容性问题); (若想使用最新版,可改为 nacos/nacos-server:latest,但生产环境建议固定版本)。

三、启动后的验证操作

命令执行成功后,可通过以下步骤确认 Nacos 是否正常运行:

  1. 查看容器状态:执行 docker ps | grep nacos,若能看到 nacos 容器且 STATUSUp(运行中),说明容器启动成功;
  2. 访问 Nacos 控制台:打开浏览器,输入 http://宿主机IP:8848/nacos(若修改了宿主机端口,需替换为自定义端口);
  3. 登录控制台:默认用户名/密码均为 nacos,登录后即可使用 Nacos 的配置管理、服务注册等功能。

四、补充说明

  • 数据存储:该命令启动的 Nacos 用内置数据库(Derby) 存储数据,仅适合测试场景;生产环境需通过 --env SPRING_DATASOURCE_PLATFORM=mysql 等环境变量,将数据存储到外部 MySQL 数据库,避免容器删除后数据丢失;
  • 版本兼容性:1.2.0 是 Nacos 的较早版本(发布于 2020 年),若需使用新特性(如配置加密、服务路由),可升级到 2.x 版本(例:nacos/nacos-server:2.3.2),但需注意版本间的配置差异;
  • 停止/删除容器:若需停止 Nacos,执行 docker stop nacos;若需彻底删除容器,执行 docker rm nacos(删除前需先停止容器)。

OpenJDK

安装目标:Mac

使用恐惧:brew

openjdk版本:8

# 查询
brew install jdk
#安装
brew install openjdk@8
# 查询软件安装列表
brew list

Maven

安装目标:Mac > > 使用恐惧:brew > > Maven版本:3.6.1 >

# 查询
brew install jdk
#安装
brew install maven@3.6.1
# 查询软件安装列表
brew list

# settings.xml
    <mirror>
      <id>alimaven</id>
      <name>aliyun maven</name>
      <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
      <mirrorOf>central</mirrorOf>
    </mirror>

Mysql

# 拉取镜像

docker pull mysql:5.7
# 运行

docker run -d -p 3306:3306 --privileged=true -v /usr/local/mysql/log:/var/log/mysql -v /usr/local/mysql/data:/var/lib/mysql -v /usr/local/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql mysql:5.7

# 配置

cd /usr/local/mysql/conf
vim my.cnf

# 配置内容
[client]
default_character_set=utf8
[mysqld]
collation_server=utf8_general_ci
character_set_server=utf8

# 进入docker mysql 命令:
docker exec -it mysql /bin/bash


# 修改密码

ALTER USER 'root'@'%' IDENTIFIED BY '<new password>' PASSWORD EXPIRE NEVER;
ALTER USER 'root'@'localhost' IDENTIFIED BY '<new password>';

Redis

安装:brew install redis
cd  /opt/homebrew/Cellar/redis/8.2.1/bin/
sudo reids-cli	

https://i-blog.csdnimg.cn/img_convert/65c6e57b090d9a9fb828ad861aee7c6f.png

Nginx

  1. 安装命令:brew install nginx 2. 查看安装信息:brew info nginx
==> nginx: stable 1.29.1 (bottled), HEAD
HTTP(S) server and reverse proxy, and IMAP/POP3 proxy server
https://nginx.org/
Installed
/opt/homebrew/Cellar/nginx/1.29.1 (27 files, 2.5MB) *
  Poured from bottle using the formulae.brew.sh API on 2025-09-15 at 21:44:38
From: https://github.com/Homebrew/homebrew-core/blob/HEAD/Formula/n/nginx.rb
License: BSD-2-Clause
==> Dependencies
Required: openssl@3 , pcre2 
==> Options
--HEAD
	Install HEAD version
==> Caveats
Docroot is: /opt/homebrew/var/www

The default port has been set in /opt/homebrew/etc/nginx/nginx.conf to 8080 so that
nginx can run without sudo.

nginx will load all files in /opt/homebrew/etc/nginx/servers/.

To restart nginx after an upgrade:
  brew services restart nginx
Or, if you don't want/need a background service you can just run:
  /opt/homebrew/opt/nginx/bin/nginx -g daemon\ off\;

解释:

安装目录:/opt/homebrew/Cellar/nginx/1.29.1

前端资源:/opt/homebrew/var/www

配置文件:/opt/homebrew/etc/nginx/nginx.conf

默认端口:8080

  1. 配置反向代理
  1. 进入到/opt/homebrew/etc/nginx l
# 进入到brew中nginx的配置目录中
cd /opt/homebrew/etc/nginx 
# 创建目录
mkdir 	leadnews.conf
# 编写app项目的配置
vim heima-leadnews-app.conf
# heima-leadnews-app.conf内容
=============
upstream  heima-app-gateway{
    server localhost:51601;
}
 
server {
	listen 8801;
	location / {
		root /opt/homebrew/var/www/app-web;
		index index.html;
	}
	
	location ~/app/(.*) {
		proxy_pass http://heima-app-gateway/$1;
		proxy_set_header HOST $host;  # 不改变源请求头的值
		proxy_pass_request_body on;  #开启获取请求体
		proxy_pass_request_headers on;  #开启获取请求头
		proxy_set_header X-Real-IP $remote_addr;   # 记录真实发出请求的客户端IP
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  #记录代理信息
	}
}
============
  1. 修改nginx.conf
 
#user  nobody;
worker_processes  1;
 
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
	# 引入自定义配置文件
	include leadnews.conf/*.conf;
}
  1. 将app前端项目放入到/opt/homebrew/var/www目录下

https://i-blog.csdnimg.cn/img_convert/5c462406b960a6bdcc93745f7c6934b6.png

  1. 重启nginx
brew serices restart nginx
  1. 浏览器访问地址:http://localhost:8801

https://i-blog.csdnimg.cn/img_convert/850efa0aad27e60cc3a4b33f5af29dd0.png