git分布式
元数据来存储
git没有一个全局的版本号
git性能优于svn
一.centos安装git:
[root@git ~]#yum install -y git
1.1 创建仓库,新增文件,提交文件:
git init 将此文件夹创建成git仓库。
git add 命令让git知道新增了文件,需要git进行版本管理。
先在git仓库中创建文件(hailong.txt),还必须将文件添加到git暂存区
git commit -m "something to say" 命令提交git仓库下的文件。其中-m参数代表提交备注.
1.2 文件修改:
git status 命令查看git仓库中文件的状态
git diff xxx 命令查看特定文件的修改内容修改后如果需要提交,需要重复git add和git commit步骤
git给出提示:
在分支master上
修改没有被暂存以供提交
使用git add 命令暂存修改,工作区到暂存区
使用git commit 命令提交修改,暂存区到版本库
被修改文件:readme.txt
此时可以使用git diff命令查看为提交的文件
按照操作步骤,先add再commit
git commit -am "一次性工作区到版本库的提交"
1.3 查看修改日志:
git log xxx命令查看文件的修改日志。日志包括 提交id(40位)、提交人、提交时间、提交备注。
git log --pretty=oneline 只看提交备注。
1.4 版本切换:
git reset 版本id 的方式切换到指定的版本,只需要输入提交id前几位就行了
git reset --HEAD 代表切换到最后一个版本
git rest --HEAD^代表切换到倒数第二个版本
git reflog XXX 查看指定文件的提交日志
$ git reset 2df107c
$ git reset -- head 2df107c
$ git reflog hailong.txt
2df107c HEAD@{0}: reset: moving to 2df107c
ed1a66b HEAD@{1}: reset: moving to HEAD^
2df107c HEAD@{2}: commit: this is new file2
ed1a66b HEAD@{3}: commit (initial): this is new file
1.5 修改回退:
git checkout ——xxx 此命令的功能是将暂存区的内容覆盖工作区。
如果已经git add 到暂存区的修改想要放弃怎么办呢? 可以先使用 git reset HEAD xxx 将指定文件的最后提交版本覆盖到暂存区,然后再使用git checkout --xxx 将暂存区的内容覆盖到工作区
$ git checkout -- hailong.txt 把暂存区hailong.txt文件覆盖到本地
1.6 删除文件:
手动删除文件后,使用git status可以发现,git版本库中文件并没有被删除。
此时有两个操作,
1是删除错了想要恢复,那么使用 git checkout --xxx 就可以恢复;
2是希望把版本库中的文件也一并删除,那么使用git rm xxxx 删除文件后,再 git commit 就行了。 (删除版本库里的文件)
红色字体代表已经删除但是还没有提交的文件
1.7 查看创建分支:
git branch // 查看目前分支
*master
git branch alan //创建分支
合并操作:
git checkout master
get merge alan
//如果有冲突,只能手动修改了。
git checkout master//切换分支
二.远程仓库GitHub:
可将本地库git的master分支push到远程仓库gitHub中,把远程仓库用jenkins集成发布测试。
2.1 登录gitHub账户,git上创建SSH KEY
https://github.com/ 账号572327713@qq.com
由于git和GitHub 之间传输文件是使用SSH加密的,所以需要创建SSH KEY:在git bash命令行输入 $ ssh-keygen -t rsa -C "youremail@dhc.com.cn",一直回车,最后在用户目录下生成.ssh文件夹。其中包含id_rsa和id_rsa.pub文件。
$ ssh-keygen -t rsa -C "572327713@qq.com"
https://github.com/baozunyuhailong/hailongRepository.git
2.2 绑定SSH KEY到GitHub
登录GitHub,在settings中找到SSH keys,点击add SSH key,
填写随便填写title,在下面的key中复制C:\Users\Jumbo\.ssh\id_rsa.pub文件中的内容后提交。
2.3关联远程仓库
登录GitHub后点击 new Repository,输入仓库名称,其他保持默认即可。
由于是免费用户,此时只能够创建public类型的远程仓库,即所有人都可见,但是只有自己控制谁可以提交。
创建成功后,会有一个远程仓库地址,如:https://github.com/baozunyuhailong/hailongRepository.git,
在本地仓库路径下使用
git remote add origin https://github.com/baozunyuhailong/hailongRepository.git
命令就可以将远程仓库与远程仓库绑定。
绑定后,使用
git push -u origin master
命令,输入GitHub用户名和密码,将本地仓库中的内容push到远程仓库。
此后,只要使用
git push origin master
就可以将本地库的master分支push到远程仓库中。
GitHub push代码发生错误:fatal: Authentication failed for 'https://github.com/ ...
可能是账号密码输入错误,也有可能代码没有commit成功
git commit -m "hahaha"
命令提交git仓库下的文件。
执行git remote -v后看到自己的remote远程端名字为origin:
$ git remote -v
origin https://github.com/baozunyuhailong/hailongRepository.git (fetch)
origin https://github.com/baozunyuhailong/hailongRepository.git (push)
执行git branch后看到自己当下用的分支是master:
$ git branch
master
然后执行git push -u origin master。
此处千万注意:不要将公司的任何与工作相关的文件上传到GitHub,否则后果自负!!!
2.4 克隆远程仓库
如果我们想要从远程库克隆,那么切换到想要创建的仓库本地目录下,并使用git clone git@github.com:xxxx/yourrepository.git就可以了。
2.5 贡献代码
如果想要为某开源仓库贡献代码,那么需要在GitHub中fork该项目到你自己的远程仓库中,然后git clone xxxx到本地仓库进行修改。修改完成后,git push origin xxxx到你自己的远程仓库中,然后pull request代码到开源项目。
三.Jenkins持续集成工具
jenkins是基于Java开发的一种持续集成工具:
1、持续的软件版本发布/测试项目。
2、监控外部调用执行的工作。
3.1 jenkins安装:
下载jenkins的war包 mirrors.jenkins-ci.org/war
启动war:
java -jar jenkins.war
不想占用8080的话,去tomcat下运行
首次登录 输入密码
获取密码:
进入选择第一个:
等待下载完成:
安装完成:
第二次登录如果忘记用户名密码,可以去配置文件删除登录画面操作。
登录就能看到用户名了。
首页:
点击系统管理配置jdk等信息:
安装主要两个插件:
安装Maven Integration plugin插件,maven自动化打包插件:
如果不安装,不能显示构建maven项目
安装Deploy to container Plugin插件,容器发布_tomcat:
自动编译,分发,打包,发布web容器(tomcat)部署,测试
配置好服务器jdk,mavne路径:
创建maven项目,配置好github后,立即构建就可打包运行了:
建立maven项目:
项目构建里配置git:
/root/ 有个.jenkins目录,目录下有workspace就是打包的项目了。
如果还想打包后继续运行tomcat,需要构建后管理的配置。
项目构建里配置tomcat:
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3652/e4d1e59f-3bb6-3499-b720-2d1cd4782dd9-thumb.png)
- 大小: 36.4 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3667/b4060276-d129-327b-8a48-4b602396644f-thumb.png)
- 大小: 41.3 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3673/e1c24c39-b5dc-3e4b-a9f7-2fbe4c04e7ea-thumb.png)
- 大小: 66.7 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3675/24b124bb-8a0c-3095-9c92-b45003a3eb4c-thumb.png)
- 大小: 87.4 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3680/38903d5b-8ff3-3fd3-87f6-46230a5f00e2-thumb.png)
- 大小: 31.2 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3682/83f40d66-b554-3f52-8259-d253c35ecda5-thumb.png)
- 大小: 45.9 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3692/e7bb17bc-36f0-33af-9883-a6c1d658a52c-thumb.png)
- 大小: 89.7 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3698/b4c990e2-b4b1-3b0c-a0fc-47a2fb08c30b-thumb.png)
- 大小: 27.6 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3702/88b53980-cae1-3bfe-b53c-b4a19a6c110e-thumb.png)
- 大小: 60.2 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3704/149fc9e6-4ade-32d4-84ef-5e22a28dc468-thumb.png)
- 大小: 100.4 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3841/0dd4587d-9a15-3eac-b471-0de42dd3d409-thumb.png)
- 大小: 26 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3849/0be08917-1b85-3fea-96e0-743438c54a6f-thumb.png)
- 大小: 39 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3851/8e0e1bf2-2d19-3780-adc9-9ad25087b13c-thumb.png)
- 大小: 20.3 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3855/79248f5e-70a5-3822-a1ab-76a5f72fb6c9-thumb.png)
- 大小: 21 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3882/1ebaace6-1b75-3a1a-9495-90e0babb46ee-thumb.png)
- 大小: 40.6 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3910/c045663f-bc3f-3f99-bba5-5750486ee59e-thumb.png)
- 大小: 42.8 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3912/ef8523a3-0d0a-3868-b97e-63acdfb6b615-thumb.png)
- 大小: 46 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3934/2cde2762-2967-397c-8956-b4bdcf21d4e5-thumb.png)
- 大小: 21 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3936/4937627c-c96b-3686-9e4e-3e5ae4eef127-thumb.png)
- 大小: 46.5 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/3940/f77f73fb-4c53-300b-babd-a12eae7fe5ab-thumb.png)
- 大小: 73.9 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4024/6e04b886-ca7c-3a89-a465-b6754c87dd92-thumb.png)
- 大小: 152.9 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4026/69da029a-c4d0-378f-9e89-7b12e50668ce-thumb.png)
- 大小: 53.2 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4028/c6bbc51a-42e4-3c23-9e63-61d0c3c3d5bc-thumb.png)
- 大小: 78.9 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4030/ef97a42d-cff6-3d31-b41c-7b901f119dc7-thumb.png)
- 大小: 53.3 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4032/643b900d-fbb6-37ee-84d5-5a98b831e6ba-thumb.png)
- 大小: 30 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4036/7e32624c-ff8a-35f5-a275-0d0a006b1c77-thumb.png)
- 大小: 72.1 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4499/6647d096-a9db-34a1-b7dd-ab0c641847b6-thumb.png)
- 大小: 134.8 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4633/0ccf957f-6a9f-3e2b-aa1f-dbd37e9666cc-thumb.png)
- 大小: 6.1 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4635/5a267624-1827-39c9-98f9-a5bd8288eca7-thumb.png)
- 大小: 36.3 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4641/8b241b1e-d781-3d76-bb88-5835c7d78c52-thumb.png)
- 大小: 53.8 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4677/81c81cd0-438a-3826-844c-360845a10e8d-thumb.png)
- 大小: 87.7 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4679/df662a99-cf9f-3cba-b953-9538cf3ae7c3-thumb.png)
- 大小: 47.6 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4681/cd56662e-e5a8-3405-98e9-407e2abcb273-thumb.png)
- 大小: 67.3 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4683/52337b7f-a1b3-39bd-bb5c-6d3fc6c2fa9b-thumb.png)
- 大小: 72.2 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4717/7abbf791-35e1-3180-87a3-28635b81e280-thumb.png)
- 大小: 57.4 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4722/61854a51-d39c-32d0-9e52-6a365ce5a001-thumb.png)
- 大小: 39 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4745/5f446060-9c60-3fa3-bfd5-7c7d066c3ba1-thumb.png)
- 大小: 73.1 KB
![点击查看原始大小图片](http://dl2.iteye.com/upload/attachment/0123/4756/1ea95dc6-7fce-351a-84d8-6fe1ab08ff32-thumb.png)
- 大小: 56.4 KB
分享到:
相关推荐
Jenkins+Git+Maven+Shell+Tomcat持续集成环境 Jenkins+Git+Maven+Shell+Tomcat持续集成环境
jenkins+git+maven搭建自动化部署环境说明文档,详尽的说明
压缩包内包括:git-2.8.0.tar.gz二进制安装包、jenkins.war应用服务war包、jenkins+git+maven+tomcat.docx搭建详细文档
jenkins+git+maven搭建自动构建项目过程,其中部分简单安装省略
jenkins+git+maven搭建自动化部署环境
"K8S+DockerCE+Jenkins+Maven+Gitlab自动化打包部署" 以下是从给定的文件中生成的知识点: 一、概述 * 自动化打包部署是指将程序从开发到部署的整个流程自动化,以提高研发效率和生产效率。 * 本文将介绍使用 K8S...
jenkins+git+maven+tomcat,自动下载代码,自动编译,自动发布到tomcat
背景:jenkins作为中央调度器,集成java、maven、git、email、html-report环境,搭建 一个自动化测试框架,可性能也可接口;maven负责项目管理,jenkins服务器就不需要安 装jmeter运行环境(错误的,maven项目配置...
Windows平台搭建Jenkins+maven+git/github实现自动发布已经越过几道坑
jenkins插件,包括maven+testNG+git+jenkins.war+HTML报表插件
Jenkins_Maven_Git 持续集成及自动化部署 GentOS版
本文以部署 Spring boot + Maven 项目为例,使用码云作为代码托管仓库,在 CentOS 7 上搭建 Jenkins 持续集成环境。 1. 准备工作 1.1 安装 Java 环境 Jenkins 是基于 Java 开发的持续集成工具,需要在 Java 环境下...
实战 Docker+Jenkins+Git+Registry 构建持续集成环境 本文将详细介绍如何使用 Docker、...通过本文,我们可以了解如何使用 Docker、Jenkins、Git 和 Registry 构建持续集成环境,实现自动化的 Java 项目发布流程。
在自动化部署流程中,Gitllab 负责管理项目的源代码,并将代码推送到 Jenkins 服务器上,以便进行自动化构建和部署。 二、 持续集成工具 Jenkins Jenkins 是一个开源的自动化服务器,提供了一个强大且灵活的平台来...
现在很多公司的Java项目开发都是使用Git或者SVN管理代码,Maven管理多模块和项目依赖,所以今天尝试学习如何使用Jenkins搭建Github与Maven下的自动构建和部署。官网下载http://jenkins-ci.org/。目前的最新版本是1....
本文章主要讲述Docker、Jenkins、GitLab、Git、JDK、SpringBoot、Maven等技术结合实现自动化运维部署(DevOps)应用工程,适合SpringCloud部署。 初衷想法:在学习过程中遇到比较有趣的问题、然而花了点心血和时间...
主要介绍了使用Jenkins配置Git+Maven的自动化构建的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Jenkins 是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。 在资源中,会讲到如下内容: - Git GitLab 安装 - Jenkins 安装 - Jenkins ...
经过近一个月的研究,完成了对maven、git、jenkins、tomcat的集成,超详细的搭建步骤,适合新人研究参考