diff --git a/.vscode/settings.json b/.vscode/settings.json index b6cbf35..b6cf8e3 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -4,6 +4,7 @@ "blackhole", "dokodemo", "fullchain", + "lastmod", "outbounds", "rprx", "VLESS", diff --git a/data/blog/archlinux-on-promox-ve-lxc.md b/data/blog/archlinux-on-promox-ve-lxc.md new file mode 100644 index 0000000..083b6d5 --- /dev/null +++ b/data/blog/archlinux-on-promox-ve-lxc.md @@ -0,0 +1,211 @@ +--- +title: 在 PVE 中运行 Arch Linux +date: '2022-02-18' +lastmod: '2022-09-17' +tags: ['Arch Linux', 'Linux', 'PVE'] +draft: false +summary: Arch Linux 的好,懂的都懂。这次在 PVE 中的 LCX 虚拟化了几个 Arch Linux 环境,用于跑一些服务和开发环境。本文主要分享了 Arch Linux 的配置步骤,其他方式入教的同志也可参考本文配置。 +--- + +# 在 PVE 中运行 Arch Linux + +Arch Linux 准入门槛确实有点高,在 PVE 中,使用 LCX 容器运行 Arch Linux,似乎是一个不错的选择,难度比物理机安装低,就是资料也少了许多……不过,问题不大,毕竟最蛋疼的部分我们可以忽略掉了。前几个月还想着直接在树莓派上安装 Arch Linux,操作一波,太难了,时间有限,就没继续搞了(没有备用设备,折腾完怕是要旷工了),最后还是再次给树每派安装了 Manjaro。 + +## 起步 + +### 0. 创建 LCX 容器 + +打开 Proxmox VE,选择你的宿主机,然后在界面右上角,点击“创建 CT”。 +然后你就看着搞咯,创建这个没有像 OpenWRT 那样讲究。 +值得注意的一点是,记得先在 PVE 中通过 `pveam` 更新并下载 Arch Linux 的模板 _([Proxmox Container Toolkit](https://pve.proxmox.com/pve-docs/chapter-pct.html#pct_container_images))_。 +进入容器后,我们将以 `root` 用户登录。 + +### 1. 配置系统 + +位置(Location) +先编辑 `/etc/locale.gen`,取消 `en_US.UTF-8 UTF-8` 的注释。 +然后执行: + +```bash +locale-gen +``` + +语言: +然后创建文件 `/etc/locale.conf`,内容如下: + +```ini +LANG=en_US.UTF-8 +``` + +命令: + +```zsh +echo 'LANG=en_US.UTF-8' > /etc/locale.conf +``` + +时区 +查看当前时区: + +```zsh +date +"%Z %z" +``` + +![image.png](https://notes.ivanli.cc/assets/image_1651218347929_0.png) +如果在中国大陆,那么执行以下命令: + +```bash +ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime +# 验证 +date +# outputs: +# Sat Jan 15 23:26:18 CST 2022 +``` + +### 2. 配置 pacman + +我们知道 pacman 是 Arch Linux 自带的包管理器,系统到手,得先装点软件,毕竟 Arch Linux 比较简约。 +首先配置 pacman 的源的镜像: + +```bash +nano /etc/pacman.d/mirrorlist +``` + +选择你喜欢并且方便连接的镜像,然后删除该行的“#”取消注释。可以选择一个或多个,在前面的优先级高。 +接下来我们更新已安装的软件,我们的哲学就是时刻保持最新。 + +```bash + pacman -Syu +``` + +**一般来说,执行上面的命令后,会拉取索引数据库,之后会优先更新 `archlinuxx-keyring`。如果不是这样的话,应当手动执行下面的代码:** +初始化并刷新 pacman 的 keys。这个 key 是 pacman 的每个用户都拥有的,包括开发者和使用者。所以执行下面两条命令: + +```bash +pacman-key --init +pacman-key --populate +pacman-key --refresh-keys +pacman -Sy archlinux-keyring +pacman -Syu +``` + +没执行上面步骤的,要手动一个个确认软件包开发者的签名……很蛋疼。如果遇到各种错误的话,可以执行下面几条命令后,再执行上面的命令: + +```bash +pacman -Sc +pacman-mirrors -f0 +rm -fr /etc/pacman.d/gnupg +``` + +_参考:[Cant Upgrade because of keyring - Technical Issues and Assistance / Package update process - Manjaro Linux Forum](https://archived.forum.manjaro.org/t/cant-upgrade-because-of-keyring/106893/10)_ + +### 3. 创建用户 + +让我们给自己分配一个具有 sudo 权限的账户 + +```zsh +useradd -m ivan +passwd ivan +usermod -aG wheel ivan +``` + +_参考:[Create a Sudo User on Arch Linux - Vultr.com](https://www.vultr.com/docs/create-a-sudo-user-on-arch-linux?__cf_chl_captcha_tk__=zPG_V_axFV3IH5lhY2j_1ChaaZgIcdPe_eYDPUOSouY-1642259505-0-gaNycGzNCZE)_ +如果 `visudo` 找不到编辑器,那么可以执行: + +```zsh +EDITOR=vim visudo +``` + +安装 `sudo`: + +```bash +pacman -S sudo +``` + +接下来使用刚刚创建的用户登录吧! + +### 4. 使用 SSH 远程登录 + +先安装 OpenSSH: + +```bash +sudo pacman -S openssh +``` + +然后启用并启动: + +```bash +sudo systemctl enable sshd +sudo systemctl start sshd +``` + +接下来就可以在其他机子上以刚刚的用户通过 ssh 访问了。 + +### 5. 安装 Yay + +安装 AUR 上的软件,怎么少得了 [[yay]] 呢?安装 Yay 需要切换到非 root 账户。 + +```bash +sudo pacman -S git +sudo pacman -S --needed base-devel +# 上面的命令有选装的项目,简单起见,全都装上 + +git clone https://aur.archlinux.org/yay.git +cd yay +makepkg -si +``` + +### 6. Zsh + +安装 Zsh + +```shell +yay -Sy zsh-git +``` + +安装 Zinit 和我常用的插件 + +```shell +sh -c "$(curl -fsSL https://git.io/zinit-install)" + +echo 'zinit load zsh-users/zsh-syntax-highlighting +zinit load zsh-users/zsh-autosuggestions +zinit load ael-code/zsh-colored-man-pages +zinit load agkozak/zsh-z +zinit ice depth=1; zinit light romkatv/powerlevel10k' >> ~/.zshrc +``` + +然后进入到 `zsh` 中,执行一次 `source ~/.zshrc`: + +```shell +zsh + +source ~/.zshrc +``` + +设置 Zsh 为默认的 shell 程序: + +```bash +# 列出所有已安装的 shell 程序 +chsh -l +# 从上面的结果中找到 zsh 的完整路径 +# 我的是 /bin/zsh +chsh -s /bin/zsh +``` + +### 7. Docker + +安装 Docker 也很简单: + +```bash +yay -S docker +# 启动 +sudo systemctl start docker +# 启用 +sudo systemctl enable docker +# 安装 Compose +yay -S docker-compose +# 添加当前用户到 docker 组 +sudo usermod -aG docker $USER +# log in to a new group +newgrp docker +```