CentOS系统上搭建Git版本控制服务器的教程
1yum安装Git服务器
代码如下:
[root@git ~]# cd src/[root@git src]# wget http://dlfedoraprojectorg/pub/epel/5/x86_64/epel-release-5-4noarchrpm
[root@git src]# rpm -ivh epel-release-5-4noarchrpm
Preparing ########################################### [100%]
package epel-release-5-4noarch is already installed
[root@git ~]# yum list
[root@git ~]# yum install -y git
2创建一个git用户,用来运行git服务
代码如下:
[root@git ~]# adduser git3创建客户端登录证书
注,收集所有需要登录的用户的公钥,就是他们自己生成的id_rsapub文件,把所有公钥复制到/home/git/ssh/authorized_keys文件里,一行一个。嘿嘿!
1)客户端生成id_rsapub文件的命令
代码如下:
$ ssh-keygen -t rsa$ cat ssh/id_rsapub
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEA6NwUHeNNi+PC6KlrcJrXXDmKxRMmgHIPp79sgX6zqfdSlmNj7rBPQeyEKS9Wg8yI6jd8aG2jsUx99Vjti2VK2vEXKkRHxwID7ri69gE71RfDtv6ekafnzLo14J8hAp0spMk+N3wEAQRYDmcYo1wmnm/jMBedGrHj4NJQ1vYy1hVtJasGMSzjcMrlz9qvaluWnQ5tQjKFQVVwKsRRRzs8qTvzVhLJt4NQ+CAN45tqfsRuf58Uba9QNK7/6xSUiIKXQiILz8PMGJ3MnlV+eN3wx2aeztdevxu9plggtG05SMmd8GNVzXrN1IaxXSvz0UwjQ2kygu7aCqO8AZWH49rouw== leo@LEO-PC
注,一路回车即可,将生成的id_rsapub,复制给管理员,帮你在服务器上增加一下,下次你用git时就不需要输入用户名和密码了。
2)查看服务器上authorized_keys文件
代码如下:
[root@git ~]# cat /home/git/ssh/authorized_keysssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAwMU4FKB6NRc3XSoIunWsdvVVuSoncbVb5Al6lB3ciswBVd++YmJFhqwkITNGccrO5sycROs9+Fbjgd6oBSzNuaBtCIbwNNsEyM/henTl2euI3XsnJQ/ITr6c/q0P3WoGl4E2QFQ2kZqs+1eDC0CgHcBrqvFv1Jr414sVYK9lfZwIF+jDdtaBOrSJuq1Agx9pGUFUEB4tQfkXxsWm/MvOmKAVvduKDE1eenUEL9zzyeELPcSXLe3NOoTjZhkX6EEXxQR1ZiZRFywLpfM4qopZ10to2KIUyVtzw6hx6V3cg7kn40lYVW0EAMATw9dVldwcRUI+kJzJSKUTKDVSwY3/+Q== root@CHENMINGQIAN
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAsmmJuR+KhRSpdSirCiL30RA8WbfgicY1z7itWVnKHJW6hTuJFhzruY59FilVjJR1hbQBluP9JnK3XPSK9PSg+bwiJ2iQRa39rXck35r+trVOLyNbPyfKVRfOemD8YuykMlyr5JeW8gZjsHEuLnJ8//RiCiYzd3RT/SSUQ4yawDoIIWkz3eUSL09xoCRZFBsAp+S/LD3vx2MN+FNOHwvqcE+yK3oRNIqjWwLoKE0e5TRnqNgrPQ95PJYB3XPUulzaeMwsWPZs7jIUMl/5yEqSgAkioa8SVMOsikYJG/erv99NNVgFmpCBIiWqKEGkNrIpYzLLHDSYQ4g5Gbci/RZ54Q== Administrator@WIN2003X323
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEA6NwUHeNNi+PC6KlrcJrXXDmKxRMmgHIPp79sgX6zqfdSlmNj7rBPQeyEKS9Wg8yI6jd8aG2jsUx99Vjti2VK2vEXKkRHxwID7ri69gE71RfDtv6ekafnzLo14J8hAp0spMk+N3wEAQRYDmcYo1wmnm/jMBedGrHj4NJQ1vYy1hVtJasGMSzjcMrlz9qvaluWnQ5tQjKFQVVwKsRRRzs8qTvzVhLJt4NQ+CAN45tqfsRuf58Uba9QNK7/6xSUiIKXQiILz8PMGJ3MnlV+eN3wx2aeztdevxu9plggtG05SMmd8GNVzXrN1IaxXSvz0UwjQ2kygu7aCqO8AZWH49rouw== leo@LEO-PC
说明:我这里有三个用户登录服务器,所以我这里就有三个ssh-rsa,大家可以看一下。
4初始化Git仓库
注,先选定一个目录作为Git仓库,这里是/data/git/projectgit。
代码如下:
[root@git ~]# cd /data/git/[root@git git]# git init --bare projectgit
[root@git projectgit]# ls
branches config description HEAD hooks index info objects refs
执行以上命令 Git命令,会创建一个裸仓库,裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以git结尾。然后,把owner改为git:
代码如下:
[root@git git]# chown -R gitgit projectgit[root@git git]# ls -l
总计 4
代码如下:
drwxr-xr-x 7 git git 4096 05-09 13:50 projectgit5禁用shell登录
注,出于安全考虑,第二步创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成。找到类似下面的一行:
代码如下:
[root@git ~]# cat /etc/passwd | grep gitgit:x:1001:1001:git version control:/home/git:/bin/bash
改为:
代码如下:
[root@git ~]# vim /etc/passwdgit:x:1001:1001:git version control:/home/git:/usr/bin/git-shell
这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。
6克隆远程仓库
注,现在可以通过git clone命令克隆远程仓库了,在各自的电脑上运行:
注,$ git clone git@gitjjhhcom:/data/git/projectgit,其中git用户名,gitjjhhcom服务器,/data/git/prgjectgit是仓库路径。好了,到这里服务器的搭建到这里就完成了,下面我们来安装一下客户端。
7创建SSH Key
首先在用户主目录下,看看有没有ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsapub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:
代码如下:
$ ssh-keygen -t rsa -C "youremail@examplecom"你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。
如果一切顺利的话,可以在用户主目录里找到ssh目录,里面有id_rsa和id_rsapub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsapub是公钥,可以放心地告诉任何人。
8Git服务器打开RSA认证
然后就可以去Git服务器上添加你的公钥用来验证你的信息了。在Git服务器上首先需要将/etc/ssh/sshd_config中将RSA认证打开,即:
1RSAAuthentication yes
2PubkeyAuthentication yes
3AuthorizedKeysFile ssh/authorized_keys
这里我们可以看到公钥存放在ssh/authorized_keys文件中。所以我们在/home/git下创建ssh目录,然后创建authorized_keys文件,并将刚生成的公钥导入进去。
然后再次clone的时候,或者是之后push的时候,就不需要再输入密码了:
代码如下:
Zhu@XXX/E/testgit/834$ git clone git@192168834:/data/git/learngitgit
Cloning into 'learngit'
warning: You appear to have cloned an empty repository
Checking connectivity done
bzzit是一个APP。
一BZZ是什么?它和swarm有什么关系?
BZZ是建立在swarm上的价值体系,为了更好的推动swarm技术的发展,需要更多的资金和矿工来参与(提供带宽和存储硬盘)!
Swarm允许用户使用自己的带宽和存储硬盘来支持以太坊上的数据,官方会给一定的代币作为奖励,这个代币就是BZZ。
他们之间是相互支撑的关系,swarm发展的越好,BZZ价格越高,BZZ价格越高,swarm有更多的矿工和资金进场,提供更多的带宽和存储推动swarm发展的更好!
可以用ipfs和fil的关系来类比,ipfs存储人类数据,需要更多的矿工提供存储服务器来存储数据,给他一定的fil奖励。BZZ也是一样的,用户提供带宽和存储来获得BZZ的奖励!
二BZZ的当前价值及未来价值
当前价值体现:不缺技术不缺资金不缺市场
未来的价值:swarm作为去中心化的分布式存储,他未来的方向肯定会是去和ipfs竞争。现在全球数据是每2年翻一番的速度增长。存储市场很大,swarm的目光一定不会局限于以太坊本身!
“放纵自己的欲望是最大的祸害,窥探别人的隐私是最大的罪恶,不知自己的过失是最大的病痛”。
上文咱们知道了目前互联网的数据安全存在隐患,数据安全的问题,每天都在发生,只不过还没有发生在你的头上而已,但是我们要知道数据安全的问题不是哪一个人的事情,而是我们所有都需要警惕,关心的!覆巢之下岂有完卵
从上文来看,咱们已经知道IPFS对标HTTP,其目标是取代传统的中心化的数据存储访问模式,我们要使用软件时又不得不接受各种隐私条款,服务商们为用户提供服时存储了大量的用户隐私数据,一旦服务商的数据中心遭到攻击,极有可能造成大规模数据泄露。所有信息都是存储在互联网公司的服务器上,我们想获取信息必须向服务器发出请求,它再传输给我们。
而这种方式随着数据的增长越来越多,越来越快,那么它的缺点就凸显得越发明显:
数据中心化:用户的隐私毫无保障,完全由这些互联网巨头存储控制。
安全性:如果网站受到攻击,我们就无法访问服务器,无法获取数据
速度慢:如果我们要访问一个服务器在外网的网站,可能需要跨越半个地球获取数据
IPFS从根本上改变了用户搜索的方式。HTTP访问服务器的时候,首先找到服务器位置(网址),然后使用路径名称在服务器上查找文件,但是通过协议IPFS,用户可以直接搜索内容。这里是怎么实现呢?
01
首先,IPFS网络里的文件,会被赋予一个哈希值(可以理解为一个独一无二的编号)然后,当用户向IPFS分布式网络询问这个编号的时候,它通过哈希表,可以快速地找到拥有数据的节点,从而检索到该数据。(类似于咱们身份证号前几位数字就可以确定是哪个省份,哪个城市,哪个县镇,一看就知道)
02
简单来讲,就是以前我们是通过跳转多层网站才能找到一个文件,但是在IPFS上存储的文件,我们只需查询它的编号,便能快速找到。并且IPFS对存储文件会自动将其切割为256KB的小区块,比如一个文件A下载浏览,B用户也下载浏览,那么C用户使用的时候,A,B用户都可以为其提供资源,这一点不像HTTP需要所有的用户从一台服务器上,下载文件,而且可以从数百台服务器上进行同步下载。所以,只要所存储的节点通电且网络正常,那么这个访问速度就可以非常快。(你打开一个网页,如果有和视频,需要慢慢加载,下载速度很慢)
03
IPFS是一种点对点的协议,而这种p2p网络需要更多的人参与进来才会提高下载速度,因此,IPFS需要更多的节点参与进来,IPFS技术应用项目也将越来越多。那么如何做到让更多的人能主动踊跃地参加进来呢?所以就有了Filcoin的激励层诞生,只要你提供了你的存储服务器有效的存储了数据,那么就会给你Fil币的奖励,这样就非常的合理了。不然你项目再怎么好,没有任何好处,别人也不会买单。
最后想说的是,现在我们还不知道IPFS协议是否能如我们所愿普遍全球,但是 历史 总是相似的,第一工业革命,以纺织机,蒸汽机的发明为标志,代表这机器代替了人工,开启了 科技 的进程;第二次工业革命,以电力的诞生,极大的推动了 社会 的进步!每一项新技术都是技术发展和时代进步的必然产物,都是在弥补上一代技术不足的技术上逐渐被构想和创建出来,而其根本价值就是让我们的生活更加便捷,让 社会 更加进步!
合法的,随着IPFS的技术落地应用越来越多,目前国家也是重力发展新基建,也就是互联网的建设,IPFS也是其中之一。那作为IPFS的激励层filecoin发行的FIL币是合法合规的。从一开始, Filecoin就遵循了这一准则。自成立以来, IPFS/Filecoin创造了许多第一纪录:第一个与实体经济联系最紧密的加密货币;第一个被传统金融机构认可的众筹加密货币;以及第一个在私慕轮中受到顶级投资机构青睐的加密货币。
:
1、FIL币:Fil币的中文名叫做文件币,它是一个开源、面向大众开放的加密货币和数字支付系统。文件币系统旨在打造一个基于区块链系统的数据存储和检索方法,它是“协议实验室”以星际文件系统为基础而创造的。IPFS全称是Inter Planetary File System,一般翻译为“星际文件系统”,它由Protocol Lab提出,是一种点对点(P2P)的分布式文件系统。
2、不过虽然说它是文件系统,是一种用来存储数据的技术,但更确切的说IPFS是一种传输协议。IPFS将HTTP视为对手,宣传上要对标HTTP,而HTTP(超文本传输协议)就是一种目前最常用的传输协议。我们要在网上找到想要的内容,就要输入网址,网址多是HTTP开头。HTTP通过域名、IP及多个中心服务器的中转,再进行文件的上传下载。HTTP的功绩无可取代,现在我们上网都要依赖于HTTP。但HTTP也存在一些问题,比如性能效率不是非常高,过度依赖于中心服务器与主干网络等等。
3、IPFS与之相比,它是一种多中心化的解决方案,内容寻址不是通过域名、IP,而是通过唯一HASH密钥来进行数据寻找。IPFS是个分布式文件存储系统,文件数据并不储存在一个中心化的服务器中,而是存储在网络上所有符合条件的电脑中。当然,IPFS不止如此,还有很多其他的特性,层次与应用范围也超过了简单的P2P下载。在IPFS中有激励机制——Filecoin,参与者(矿工)通过贡献存储空间和带宽,可以获得加密货币Filecoin奖励。
阿尔伯塔省。根据BlackRockPetroleum发布的声明,在与OptimumMiningHost达成协议,将在未来24个月陆续把百万台比特币矿机搬迁到加拿大阿尔伯塔省,阿尔伯塔省关于比特币挖矿的监管可以说是走在了加拿大前列。FIL币是基于分布式存储系统IPFS而发行的代币,FIL币矿机实际上是一种分布式存储数据服务器。
Filecoin是IPFS上的一个代币,而Filecoin就是通过贡献闲置的硬盘来作为奖励矿工的一种方式。Filecoin采用了一种全新的算法(工作量证明),简单的来说,你拥有的硬盘容量够大,那么你获取的Filecoin奖励就越多。Filecoin通过经济激励的机制来促进IPFS的发展,同时Filecoin网络也需要IPFS为其市场的发展提供生态支持。IPFS网络使用的越多,对Filecoin的需求就越大;Filecoin的矿工越多,对IPFS网络的也就支持越大。所以IPFS和Filecoin形成了共生关系。Filecoin的诞生是为了支持IPFS的发展,IPFS也需要Filecoin为其丰富生态。IPFS使用的越多,Filecoin的需求更大;Filecoin的矿工越多,对IPFS的支持越大。
FIL
FIL的作用——Filecoin是一个去中心化分布式存储网络,是IPFS的唯一激励层。Filecoin采用了区块链通证体系发行了Token,Token简称FIL。Filecoin基于IPFS协议将云存储构建了一个去中心化的存储交易市场,包括「存储」和「检索」两个市场。这个市场运行在有着本地协议令牌(FIL)的区块链,矿工可以通过为客户提供存储来获取FIL;同样的,客户可以通过花费FIL来雇佣矿工来存储或分发数据。更多人关注Filecoin是因为有70%的代币是通过挖矿释放出来的,但是很多人对于Filecoin的挖矿收益还是有些误区。我们所说的挖矿,其实是一个铸币的过程,也就是网络通过区块奖励将代币释放出来,然后才有代币的流通、交易和使用,矿工也就有逐渐开始有存储收益和检索收益。像比特币一样,早期矿工通过挖矿获得区块奖励,然后比特币逐步被更多的人接受并开始广泛流通和交易,目前每天链上转账近30万笔,比特币矿工除了区块奖励以外还有矿工费也就是交易手续费的收益。所以,在Filecoin网络发展初期,通过区块奖励的方式激励矿工贡献自己的服务器来建设分布式存储网络,当Filecoin网络的基础建设好了之后,网络的安全性、稳定性达到一定程度的时候,就会有越来越多的机构和个人开始将自己的数据存储到Filecoin网络的服务器上,矿工就开始产生的存储挖矿的收益。随着Filecoin网络上存储真实数据越来越多,自然就会产生检索需求,矿工就会有检索挖矿的收益。
链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站 ”唯一获准的“区块链技术专业”试点工作站。专业站立足为学生提供多样化成长路径,推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系。
2023年尚未公布FIL减半的消息。
Filecoin是IPFS上的一个重要应用,是一个去中心化的分布式存储,它也是IPFS上唯一的激励层,Filecoin的诞生是为了通过经济激励的机制来促进IPFS的发展,IPFS网络使用的越多,对 Filecoin的需求就越大。Filecoinl的矿工越多,对PFS网络的支持也就越大。所以IPFS和 Filecoin形成了共生关系。
Filecoin(简称FIL)是IPFS的激励层代币,是一个真正的区块链项目,我们参与到IPFS的网络中来,为IPFS提供服务器,而我们得到奖励则是Fil币,而Fil币则是我们投资回报的变现途径。它是一个基于区块链分布式的存储网络,它把云储存变成一个算法市场。
相关背景
2017年,协议实验室创建了基于IPFS的去中心化存储网络Filecoin,旨在构建去中心化、高效的基础设施网络。这是一个基于指数表的众筹项目,也可以认为是指数表的激励层。很多人对IPFS和Filecoin之间的关系感到困惑。就像区块链和比特币,区块链是一种技术,而比特币是该技术的应用。
类似地,IPFS是一种技术,而Filecoin是这种技术的应用程序。同年,Filecoin在其自建平台上在半小时内筹集了合规代币融资,使其成为当时融资最多的区块链项目。目前主网在2020年10月15日Filecoin上线,全球头部交易所免费上线FIL。
0条评论