创建模板(debian13)
准备工作
以 debian 13 为例,debian13 后开发服务器不再是一台独立服务器和两块单独的 ssd 硬盘。所有构建方式和之前的有比较大的差异。
准备虚拟机
从模版 template-debian13-basic-v01 (取最新版本) full clone 克隆一个虚拟机,命名为 template-debian13-devserver-v01,VM ID 为 990201.
开发需要的 cpu 和内存稍大,修改虚拟机参数,cpu 修改为 8 核,内存 16g(mini 8192,memory 16384)。
准备磁盘
devserver 预计会有两台实例,用于两个异地的开发环境。
为每台实例准备了 2 块两块额外的磁盘,一块用于应用(如数据库,redis,queue等),一块用于数据(如pve需要的nfs,habor / nexus 代理仓库等)。在虚拟机硬件中,增加两块 hard disk,大小为 1024g,scsi 类型,virtIO scsi 控制器。注意把 backup 选项勾选去掉。
在 pve 中,将两块 hard disk 磁盘添加到虚拟机:

在虚拟机中可以看到这两块磁盘:
lspci | grep storage
09:01.0 SCSI storage controller: Red Hat, Inc. Virtio SCSI
09:02.0 SCSI storage controller: Red Hat, Inc. Virtio SCSI
09:03.0 SCSI storage controller: Red Hat, Inc. Virtio SCSI
文件共享
数据存放在 /mnt/data 目录下,包括:
- downloads: 下载的文件
- pve-shared: pve 共享目录
- shared: 共享目录
sftp 服务
安装了 sftp 服务,可以用于上传和下载文件。
nfs 共享
其中 pve-shared 目录用于 pve 共享目录,shared 目录用于其他的共享,两者都挂载到 nfs 服务器上。
参考本读书笔记中的 devserver193 一节, 配置好磁盘并进行分区,并挂载到 /mnt/data 和 /mnt/app 目录, 然后安装 nfs server。
nginx下载
另外新建一个 downloads 目录,用于存放供其他机器下载的文件,通常是只读的,通过 nginx 提供 http 下载服务。
$ cd /mnt/data
$ ls
downloads lost+found pve-shared services shared
$ cd downloads
$ ls
docker docker-compose kubernetes
然后修改 nginx 配置,将 downloads 目录映射到 /var/www/html/downloads 目录。
sudo vi /etc/nginx/sites-available/default
添加如下配置:
location /downloads {
alias /mnt/data/downloads;
autoindex on; # 开启目录浏览
autoindex_exact_size off; # 显示文件大小时用 KB/MB
autoindex_localtime on; # 显示本地时间
}
然后重启 nginx 服务:
sudo systemctl restart nginx
搭建开发环境
安装 docker 和 habor
- docker/docker-compose: https://skyao.net/learning-docker/docs/installation/debian12/
- habor: https://skyao.net/learning-docker/docs/repository/habor/
安装开发工具
参考本读书笔记中的 开发工具 一节, 安装开发工具:
- sdkman
- nexus
语言 sdk 和 nexus 私库
参考本读书笔记中的 编程语言 一节, 安装语言 sdk 和对应的 nexus 私库:
- Java: 包括 maven
- golang
- rust
- python
- nodejs