问题起源:springboot项目启动报错 在根目录下无法创建/data 存放项目日志

ERROR in ch.qos.logback.core.rolling.RollingFileAppender[APP] - Failed to create parent directories for [/data/apps/项目名/logs/app.log]

试着手动创建去解决,失败

admin@admindeMacBook-Pro-2 ~ % cd /         
admin@admindeMacBook-Pro-2 / % sudo mkdir data
Password:
mkdir: data: Read-only file system

遂搜寻解决方案,搜寻关键词:mac 根目录无法创建 mac / 权限 log mac 启动项目 文件夹 mac 运行项目 文件夹 mac 启动项目 权限 mac 运行项目 权限

放在前面

根目录无法创建文件夹

此故障出现在10.15 Catalina版本及以后,系mac新的安全性策略所带来的欢快

我的开发环境:macOS 11.3 Big Sur

0.手动修改配置文件 日志写入路径

以公司项目为例记解决办法

## 原配置
logdir: /data/apps/java-${spring.application.name}-controller/logs

## 本地修改路径
logdir: /Users/admin/Downloads/java-${spring.application.name}-controller

都是团队开发,此法不建议使用,git 极不方便

1.关闭SIP,/ 下新建软连接到用户 /data

SIP 全称为「System Integrity Protection」即「系统完整性保护」,是系统级的权限操作,我们无法直接关闭它,需要前往「macOS 恢复功能」下进行。

先查看SIP状态:csrutil status 默认enabled。

此法不是苹果官方推荐,但貌似Catalina可用,BigSur不可用。

2.man synthetic.conf,官方软连接方案

最终解决办法,Big Sur可用,Monterey未知。

## 0.查看synthetic.conf说明
man synthetic.conf
## 1.vim 修改synthetic.conf(没有会创建)
sudo vim /etc/synthetic.conf

## 2.添加一行记录(使用 tab 进行分割,空格 换行,使用空格分割会发现重启无效)

## 以此处举例

data	/Users/admin/data

## 重启后,在根目录下已经创建好 data 软连接到 /Users/admin/data
ls -al
......
lrwxr-xr-x   1 root  wheel    17  7 21 14:45 data -> /Users/admin/data
......