由于在使用各种商业云笔记时遇到过各种不便,一直未能找到适合自己的云笔记,所以决定基于各种工具搭建一个云笔记来使用。
笔记客户端选用VS Code,既有简便灵活的用户界面,也有丰富的插件。安装好Markdown、LaTex、Python等插件后,可以灵活的使用文本来编辑格式各样的笔记,也可以实时运行编辑的代码、脚本。
数据存储和版本管理选用Git来实现,主要是考虑到便于协作、易于实现。另外,Git可以只依赖本地数据做编辑,这样离线场景也可以正常使用。
二、详细实现方案
2.1 部署架构
本地使用VS Code作为客户端,通过Git协议与云服务进行连接。服务器端采用1主N备架构进行部署,以对数据进行冗余备份。
2.2 主服务器部署
(1)创建用户和用户组
需要在主服务器上创建新的用户和用户组来隔离权限,使用“adduser”命令创建一个新的用户和用户组“git”:
[root@server ~]# sudo adduser git
执行成功后可以通过命令“cat /etc/group”看到创建的用户组:
[root@server ~]# cat /etc/group
root❌0:
bin❌1:
daemon❌2:
sys❌3:
adm❌4:
tty❌5:
···
git❌1000:
[root@server ~]#
使用命令“passwd”可以清除用户git的密码:
[root@server ~]# passwd -d git
清除用户的密码 git。
passwd: 操作成功
原则上用户git不允许登录,只能用来push/pull。可以通过编辑“/etc/passwd”,将用户git原本的“/bin/bash”更改为“/usr/bin/git-shell”来实现。
git❌1000:1000::/home/git:/usr/bin/git-shell
接着切换到git用户,以便于后续操作,否则以root账户操作会有额外需要调整权限。
[root@server ~]# su git
(2)初始化中心Git仓库
在主服务器安装好Git后(安装Git参见附录4.1),就可以使用“git init”命令创建中心仓库:
[git@server ~]# cd /home/git
[git@server git]# git init --bare ./repo.git
已初始化空的 Git 仓库于 /home/git/repo.git/
选项“bare”说明创建的是一个裸库,仅用于存取分支数据。
若初始化是以root账户操作,那么最后需要更新目录所有者为用户“git”:
[root@server git]# chown -R git:git repo.git
再次查看仓储目录可以看到目录所有者已经变更:
[root@server git]# ls -l
总用量 0
drwxr-xr-x 2 git git 6 3月 12 13:58 repo.git
2.3 备服务器部署
(1)创建用户和用户组
参考主服务器部署步骤(1),在备服务器上创建好用户和用户组“git”。
(2)克隆中心Git仓库
接着克隆主服务器上存储的Git库:
[git@backup_server ~]# git clone --bare git@server_address:/home/git/repo.git repo.git
克隆到裸版本库 ‘repo.git’…
git@server_address’s password:
warning: 您似乎克隆了一个空版本库。
[git@backup_server ~]#
其中”server_address“替换为主服务器地址(下文同)。
若初始化是以root账户操作,那么最后需要更新备份目录所有者为用户“git”:
[root@backup_server git]# chown -R git:git repo.git
2.4 配置主备服务器自动同步
(1)配置免密访问
在主服务器上使用”ssh-keygen“生成一个新的SSH密钥对:
ssh-keygen -t rsa -b 4096 -C “your_email@example.com” -f /home/git/.ssh/id_rsa
这里”-t“用于指定密钥类型,rsa是目前广泛使用的密钥类型。”-b“用于指定密钥长度,4096位提供了很好的安全性。”-C“是可选的,用于添加一个注释,通常是电子邮件地址。”-f“是可选的,用于指定输出文件路径。
[git@server ~]# ssh-keygen -t rsa -b 4096 -C “system” -f /home/git/.ssh/id_rsa
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/git/.ssh/id_rsa.
Your public key has been saved in /home/git/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:qIyYdf+MdQkJdmeWAHh5QhP60EMwMKFkEfeOHk2YYnA system
The key’s randomart image is:
±–[RSA 4096]----+
|.=E+o+*+. |
|+o…==+… . |
|.o oo+=o. = |
|. . =+ = = |
| .o.oo S |
| +.+.o . . |
|o …o . . o |
| = . |
| . o |
±—[SHA256]-----+
[git@server ~]# chown -R git:git /home/git/.ssh/
[git@server ~]# ls /home/git/.ssh/
authorized_keys id_rsa id_rsa.pub
最终生成了”id_rsa“和”id_rsa.pub“两个密钥文件,其中”id_rsa“是私钥,”id_rsa.pub“是公钥。
接着将公钥通过”ssh-copy-id“命令添加到备服务器,完成后就可以免密访问了。
[git@server ~]# ssh-copy-id -i /home/git/.ssh/id_rsa.pub git@backup_server_address
其中”backup_server_address“替换为备服务器地址(下文同)。
(2)配置同步脚本
在主服务器上新建”post-receive“钩子脚本,并且为脚本添加执行权限。
[git@server ~]# touch repo.git/hooks/post-receive
[git@server ~]# chmod +x repo.git/hooks/post-receive
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Go语言工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Go语言全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Golang知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-0ETqA6LG-1713039527494)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!