博客用的服务器vps崩溃救援记录

最近发现博客不在线了,查看vps发现centos系统无法进入了,卡在了启动项选择界面,选哪个都是无法进入的状态.

要编辑重要文件,所以先备份了系统

搜索发现可以通过编辑grub的方式启动,但是刚开始没弄明白分区,写错了/dev/sda1(实际是/dev/vda1),
而且编辑initramfs路径时没有tab提示,最终无法正确启动进入系统.

经过一番摸索发现,cloudcone有个恢复模式,进入恢复模式后,相当于用live镜像进入系统,但是不会直接操作原来的系统文件.询问文心一言后,学会了:

1. 先进入恢复系统
2. 使用lsblk、fdisk -l等命令来查看分区设备名
3. 挂载系统分区
mkdir -p /mnt/sysimage  #创建一个空文件夹
mount /dev/vda1 /mnt/sysimage #把设备分区挂载到这个文件夹上
4. 绑定/dev、/sys和/proc目录到挂载的系统分区中,以便chroot环境能够正常工作:
mount --bind /dev /mnt/sysimage/dev  
mount --bind /sys /mnt/sysimage/sys  
mount --bind /proc /mnt/sysimage/proc
5.使用chroot命令切换到挂载的系统分区:
chroot /mnt/sysimage
6. 为了省事直接重新生成initramfs
dracut --regenerate-all --force #会卡一会,等待
7. 在执行 grub2-mkconfig 命令时遇到 “command not found” 的错误,所以直接重新安装了 grub2:
yum install grub2
8.然后重新生产了grub.conf
grub2-mkconfig

提示成功后,退出恢复模式,重启系统,启动成功!
太激动了,AI确实能解决实际问题.

kapt不兼容JDK 16:KaptContext cannot access class com.sun.tools.javac.util.Contex

原文链接:https://blog.csdn.net/lovelease/article/details/126868466
问题
项目使用了 kotlin 的 kapt 插件添加某个依赖,打包 APK 时报错:

  • What went wrong:
    Execution failed for task ':network:kaptDebugKotlin'.

    A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptWithoutKotlincTask$KaptExecutionWorkAction
    java.lang.reflect.InvocationTargetException (no error message)

是 task:kaptDebugKotlin 失败了,使用 --stacktrace 重新编译打包,得到更详细的错误提示:

Execution failed for task ':app:kaptDebugKotlin'.
> A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptWithoutKotlincTask$KaptExecutionWorkAction
   > java.lang.reflect.InvocationTargetException (no error message)

* Try:
Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Exception is:
org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:kaptDebugKotlin'.
    ...
Caused by: org.gradle.workers.internal.DefaultWorkerExecutor$WorkExecutionException: A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptWithoutKotlincTask$KaptExecutionWorkAction
    ...
Caused by: java.lang.reflect.InvocationTargetException
    ...
    ... 3 more
Caused by: java.lang.IllegalAccessError: class org.jetbrains.kotlin.kapt3.base.KaptContext (in unnamed module @0x1f74be16) cannot access class com.sun.tools.javac.util.Context (in module jdk.compiler) because module jdk.compiler does not export com.sun.tools.javac.util to unnamed module @0x1f74be16
    at org.jetbrains.kotlin.kapt3.base.KaptContext.<init>(KaptContext.kt:29)
    at org.jetbrains.kotlin.kapt3.base.Kapt.kapt(Kapt.kt:33)
    ... 31 more

可见,根本问题是:

Caused by: java.lang.IllegalAccessError: class org.jetbrains.kotlin.kapt3.base.KaptContext (in unnamed module @0x1f74be16) cannot access class com.sun.tools.javac.util.Context (in module jdk.compiler) because module jdk.compiler does not export com.sun.tools.javac.util to unnamed module @0x1f74be16

分析
先大概介绍一下 KAPT,它是 kotlin 用来支持 Android 的注解处理的一个插件,把java使用 annotationProcessor 添加的依赖改为使用 kapt,比如:

// java
annotationProcessor 'com.squareup.moshi:moshi-kotlin-codegen:1.12.0'
// kotlin
kapt "com.squareup.moshi:moshi-kotlin-codegen:1.12.0"

该问题官方已经有回复了,见:https://youtrack.jetbrains.com/issue/KT-45545/Kapt-is-not-compatible-with-JDK-16 ,这里总结一下:

KAPT 是基于 javac 的 internal API 编译的,但 JDK 16 对 internal API 做了访问限制,因此这可以说是 KAPT 与 JDK 16 的兼容问题。

解决方案
方案一:降低 JDK 至 16 以下

不用多说了,既然是与 16 的兼容问题,降低版本自然能解决。

方案二:指定jvm参数,允许illegal-access(推荐)
gradle.properties 中添加:

org.gradle.jvmargs=--illegal-access=permit

方案三:指定 kapt 运行在 kotlin deamon 中
kapt默认运行在gradle deamon中,可以通过以下配置强制其运行在kotlin deamon中,但可能会使其变慢。

gradle.properties 中添加:

kapt.use.worker.api=false

git报错 fatal: unsafe repository 解决方法 xxx is owned by someone else

原文:https://www.aspirantzhang.com/network/git-fatal-unsafe-repository.html

git近期进行了版本升级,添加了新的目录安全限制。造成在进行git常规操作时,或在各类编辑器如VSCode中无法发现.git文件,报错:

fatal: unsafe repository(xxx is owned by someone else.)
To add an exception for this directory, call
git config –global –add safe.directory

本文介绍处理方法。

处理方案1:忽略单个目录

哪个目录里有git,就通过命令行添加哪个目录,多个目录,多次添加。

git config --global --add safe.directory D:/www/your-project
git config --global --add safe.directory D:/www/other-project

处理方案2:忽略全部文件夹

可以通过加通配符为*,忽略所有文件夹。需要注意,该处理方法一般适用于只有本人一个用户使用的电脑,确保无其它用户,否则存在安全问题。见下方详述。

git config --global --add safe.directory "*"

一个项目设置两个git地址,并最终实现一次性同时推送到到两个git地址上

原文地址:https://www.cnblogs.com/teamemory/p/11607613.html

基于多处备份的想法,确保自己的代码不丢失。或者是代码的git本身搭建在自己公司的服务上,而你为了保险起见,想把项目同时放在码云或者github上面。
这样,你就需要让一个项目同时备份在两个云端,这样即使公司的服务器上面的代码丢了,或者公司服务器把你的名单除名了,你仍然在码云或者github上面存有你的代码。
那么,怎么实现这个想法呢?请看如下步骤:

前提:

1、假设你现在在gitLab上面新建了一个git地址A(里面已经有项目内容)

git@git.taotiangou.net:teamemory/myh5.git

2、假设你同时在码云上面同样新建了一个git地址B (可能是一个新建的空白项目内容地址)

git@gitee.com:teamemory/myH5.git

现在想实现我在git地址A项目中,提交代码的同时,可同时提交到git地址B 。

方法1:(需要push两次,不符合题目要求,但是优点是可以pull两次)

步骤1:
在git A 项目中添加另一个git B远程的地址

git remote add origin2 git@gitee.com:teamemory/myH5.git    // origin2可以自定义

步骤2:
先拉取git B 该地址上的数据

git pull origin2 master --allow-unrelated-histories   (--allow-unrelated-histories是为了解决冲突)

步骤3:
在git A 项目中把项目内容同步到git B地址中

git push origin2 master

此时,我们基本实现了可以把一个项目可以提交到两个git地址了,但是每次提交内容都需要进行如下两次提交,才能实现把一个项目同时提交到两个git地址。

git push origin  master
git push origin2 master

问题来了,我们想要的实现的是,我提交一次,就能同步两个项目,怎么继续实现呢?请看方法2
注意:删除上面的添加的git B的远程地址

git remote -v  // 查看此时的包括两个远程地址
git remote rm origin2  // 删除git B的远程地址
git remote -v  //此时应该只有git A的远程地址

方法2:(只需要push一次)

给origin 增加一个可以push的地址

git remote set-url --add origin git@gitee.com:teamemory/myH5.git   //给origin添加一个远程push地址,这样一次push就能同时push到两个地址上面
git remote -v //查看是否多了一条push地址(这个可不执行)

至此,我们就可以直接一个push,同时推送到两个git地址。

git push origin master -f    // 如果第一次推不上去代码,可以使用强推的方式

注意:删除添加的路径的方法是

git remote set-url --delete origin git@gitee.com:teamemory/myH5.git

至此,我们建议一次push实现两个git项目的沟通,建议使用方法2!!!