照片的拍摄日期如何修改照片拍摄日期?不是属性——详细那里的修改,是用TXT记事本打开照片,然后找到拍摄日期,我

很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。

Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?

事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!

你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。

不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。

安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。

Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:

Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。

Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。

历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

  • 从定义上来说Git就是一个分布式版本控制系统
  • 从作用上来说Git就是管理一些文本或者代码的版本更新,例如内容的改动
  • 从管理的对象来说,所有的版本控制都只能针对文本内容,像word这样的二进制内容,所谓版本,就是文件快照,不能比较差异,只能算带备份的网盘

如果要想了解分布式是什么意思,那么我们得先去了解它的对立面集中式

  • 工具:CVS及SVN都是集中式的版本控制系统
  • 内容:集中式版本控制系统集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
  • 缺点:集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟,这还不得把人给憋死啊。

内容:布式版本控制系统没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。

优点:和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。当然,Git的优势不单是不必联网这么简单,后面我们还会看到Git极其强大的分支管理,把SVN等远远抛在了后面(svn其实也有分支功能,不过是在服务器上的分支)

集中式与分布式的差异性

  1. 分布式在每一个用户上都有一个版本控制而集中式没有
  2. 由于每一个用户都有自己的版本控制工具,所以服务器压力几乎没有,而集中式版本工具的压力全在服务器上,所以在协作人数上面分布式版本工具更胜一筹

可以直接从官网下载相应操作系统的Git然后进行安装,当然也可以使用命令行的方式

  • 例如在使用Centos操作系统的时候,可以使用如下命令快速安装

  
  • 或着不想使用命令行方式就直接去官网下载压缩包
 测试两个文件提交留一个文件不提交

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数


  

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交>

可以拿到所有的操作记录

从下面我们可以找到带有commit字样的就是我们之前创建的版本,但是只提供了ID的七为数,但是没关系,git会自动识别出来

HEAD 现在位于 3956cc3 测试两个文件提交留一个文件不提交

首先是官图解释,从下图可以看出如果我们想直接提交文件到master分支上,那么直接使用 git commit -a即可

接着再看看其余大佬绘制的图

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD

假如我们在commit之后没有任何操作,那么我们暂存区就是空的

当我们添加了文件或者修改了文件,并且使用了add命令那么暂存区stage就又有了文件

当我们使用commit提交之后,那么早存区又变成了空

  • git diff 比较的是工作区文件与暂存区文件的区别(上次git add 的内容)

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file

首先修改工作区的文件,不执行add操作

检查git状态,发现提示使用git checkout -- file 命令撤回操作 ,执行之后发现已经成功撤回

# 尚未暂存以备提交的变更:

对强迫症童鞋来说,现在事情有点不对头,提交历史分叉了。如果现在把本地分支push到远程,有没有问题?

这个时候,rebase就派上了用场。我们输入命令git rebase试试:


  

还可以创建带有说明的标签,用-a指定标签名,-m指定说明文字


  

这样一来,我们的本地库就可以同时与多个远程库互相同步:

┌─────────┐ ┌─────────┐
└─────────┘ └─────────┘
 └─────┬─────┘
 ┌─────────────┐
 └─────────────┘

  

配置别名也可以直接修改这个文件,如果改错了,可以删掉文件重新通过命令配置。

给Git配置好别名,就可以输入命令时偷个懒。我们鼓励偷懒。

在一节中,我们讲了远程仓库实际上和本地仓库没啥不同,纯粹为了7x24小时开机并交换大家的修改。

GitHub就是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。

搭建Git服务器需要准备一台运行Linux的机器,强烈推荐用Ubuntu或Debian,这样,通过几条简单的apt命令就可以完成安装。

假设你已经有sudo权限的用户账号,下面,正式开始安装。(在这里我使用的是Centos)


  

第二步,创建一个git用户,用来运行git服务


  

第三步,创建证书登录:

收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub文件,把所有公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。

第四步,初始化Git仓库:

先选定一个目录作为Git仓库,假定是/srv/sample.git,在/srv目录下输入命令:


  

Git就会创建一个裸仓库,裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。然后,把owner改为git(用户权限)


  

第五步,禁用shell登录:

出于安全考虑,第二步创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成。找到类似下面的一行:


  

  

这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。

第六步,克隆远程仓库:

现在,可以通过git clone命令克隆远程仓库了,在各自的电脑上运行:


  

如果团队很小,把每个人的公钥收集起来放到服务器的/home/git/.ssh/authorized_keys文件里就是可行的。如果团队有几百号人,就没法这么玩了,这时,可以用来管理公钥。

这里我们不介绍怎么玩了,几百号人的团队基本都在500强了,相信找个高水平的Linux管理员问题不大。

有很多不但视源代码如生命,而且视员工为窃贼的公司,会在版本控制系统里设置一套完善的权限控制,每个人是否有读写权限会精确到每个分支甚至每个目录下。因为Git是为Linux源代码托管而开发的,所以Git也继承了开源社区的精神,不支持权限控制。不过,因为Git支持钩子(hook),所以,可以在服务器端编写一系列脚本来控制提交等操作,达到权限控制的目的。就是这个工具。

这里我们也不介绍了,不要把有限的生命浪费到权限斗争中。

  • 搭建Git服务器非常简单,通常10分钟即可完成;

  • 要像SVN那样变态地控制权限,用。

经过两天的学习,站在巨人的肩膀上,我把命令都执行了一遍,大概有了个印象。

Git虽然极其强大,命令繁多,但常用的就那么十来个,掌握好这十几个常用命令,你已经可以得心应手地使用Git了。

友情附赠国外网友制作的Git Cheat Sheet,建议打印出来备用:

现在告诉你Git的官方网站:,英文自我感觉不错的童鞋,可以经常去官网看看。

來源:廖雪峰的官方网站  

京东上的所有商品信息、客户评价、商品咨询、网友讨论等内容,是京东重要的经营资源,未经许可,禁止非法转载使用。

注:本站商品信息均来自于合作方,其真实性、准确性和合法性由信息拥有者(合作方)负责。本站不提供任何保证,并不承担任何法律责任。

京东价:京东价为商品的销售价,是您最终决定是否购买商品的依据。

划线价:商品展示的划横线价格为参考价,并非原价,该价格可能是品牌专柜标价、商品吊牌价或由品牌供应商提供的正品零售价(如厂商指导价、建议零售价等)或该商品在京东平台上曾经展示过的销售价;由于地区、时间的差异性和市场行情波动,品牌专柜标价、商品吊牌价等可能会与您购物时展示的不一致,该价格仅供您参考。

折扣:如无特殊说明,折扣指销售商在原价、或划线价(如品牌专柜标价、商品吊牌价、厂商指导价、厂商建议零售价)等某一价格基础上计算出的优惠比例或优惠金额;如有疑问,您可在购买前联系销售商进行咨询。

异常问题:商品促销信息以商品详情页“促销”栏中的信息为准;商品的具体售价以订单结算页价格为准;如您发现活动商品售价或促销信息有异常,建议购买前先联系销售商咨询。

记事本文件TXT格式,字体大小为什么不能改变,有什么办法吗?... 记事本文件TXT格式,字体大小为什么不能改变,有什么办法吗?

可选中1个或多个下面的关键词,搜索相关资料。也可直接点“搜索资料”搜索整个问题。

可以改变,但只是显示上的变化,文件本身是不变的。

打开记事本文件,在工具栏中有个格式,然后选字体。。里面都可以改了 大小 加粗 什么都有的,亲可以慢慢选哦!!!

我要回帖

更多关于 怎么修改照片属性日期 的文章

 

随机推荐