jenkins
- 下载Jenkins
- 将jenkins.war 复制到Apache Tomcat下的webapps下面
- 启动apache tomcat 将会自动将jenkins.war解压到webapps下面,解压结束之后
- 访问jenkins
- 在系统管理发现反向代理设置错误时候,直接[ 系统设置 ],将下面的jenkins url后面的/jenkins去掉,问题解决
配置web hook 与jenkins
- 系统设置 --> 管理插件 --> 可选 -->搜索Generic Webhook Trigger -->安装
- 在jenkins新建任务,自由风格 选用Git( 源码管理 )
- 设置Generic WebHook Trigger 参数(设置好用户名与密码),保存
- 记住当前的地址(jenkins task url)
- 到码云上的项目中,在 管理 添加WebHooks 粘贴(jenkins task url)
- 进行测试,通过,基本模式结束
注意利用ngrok对本机地址进行反向代理,处理为公网地址,完成本地测试
Gitee插件的应用:可以直接在任务中设置gitee的地址,生成密码,直接使用配置插件项目的说明的地址和密码,填充到码云的webhook中直接可用,jenkins+gitee插件配置
自动化环境配置安装
新建节点问题解决:
- 系统管理,系统安全配置,代理(随机选取),代理协议(Java Web Start Agent Protocal)
- 系统设置,节点管理,新建节点,节点名称(复制,或者固定),设置基本参数(远程目录,用法,启动方式选择
通过Java Web启动代理
- 点击保存launch上的slave-agent.jnlp文件,
- 发生找不到remoting.jar文件时候,将apache tomcat下面的remoting-xxx.jar复制到目标路径,一般相对于apache webapps下面的目录路径,并保存为remoting.jar,
- 启动slave-agent.jnlp,建议使用管理员权限从cmd上启动,之后安装为服务
- 服务名称:hebjubsskave-D_Slave
- 通过查看控制台输出结果进行判定当前运行结果如何
码云对svn的支持只停留在传输与校验上,无法支撑文件路径的权限管理,放弃继续的深究
以上为码云+jenkins的可持续集成环境的探索
Git 使用与码云
基本链接流程
-
安装git
-
命令行设置(全局)信息
git config --global user.name "name"
git config --global user.email "email"
-
初始化仓库
git init
-
添加文件
git add <file····>
-
提交到仓库
git commit -m <message>
-
检测状态
git status
直接显示当前本地仓库中的文件变化情况 -
检测文件变化
git diff <file>
直接查看文件的修改内容 -
历史记录
git log [--pretty=oneline]
显示变化的历史记录 -
回退版本
git reset --hard HEAD^
回到上个版本
git reset --hard 1994ds
回到特定的版本,版本号不需要 写全,git能够自动寻找,但是不能太简单,一般选择前几位
git reset --hard commit_id
-
修改与提交
第一次修改-->git add
-->第二次修改-->git add
-->git commit
git add 将修改的文件提交到暂存区,之后才能加入到commit
中的 -
撤销修改
a.git checkout -- <file>
撤销修改,让修改回到上一次git commit
或者git add
状态
b.git reset head <file>
将暂存区的修改撤销掉,重新放回工作区
已经添加到暂存区时候,先执行b 之后执行a -
删除文件
git rm <file>
删除文件
手动删除文件之后,git rm <file> 和git add <file>效果一致
git checkout -- <file>
将删错的文件恢复 -
远程仓库
git remote add origin <(.git) url>
-
推送
git push -u origin master
将当前分支master推送到远程,第一次推送的时候 -u git会把本地master分支内容推送到远程新的master分支,还会把本地master和远程master分支关联起来 -
创建分支
git checkout -b dev
创建并切换到分支 (-b) -
查看分支
git branch [branchname]
查看当前分支,查看指定分支
git merge <branchname>
合并分支到master中
git brach -d <name>
删除分支 -
冲突管理
git status
或者直接commit时候查看冲突情况,手动修改冲突,完成提交与分支合并
master 分支尽可能保持稳定,一般情况下选择在其他分支上工作,到发布的时候在完成分支合并
合并分支--no--ff
参数使用普通合并,合并后存在历史分支,能看出来曾经做过合并,fast forward
则不行 -
Bug分支
git stash
隐藏当前工作现场,等恢复之后再继续工作
git status
git checkout master
git merge --no-ff -m "merged bug fix 101" issue-101
git stash list
查阅工作现场
git stash pop
恢复工作现场,并删除stach(可以git stach apply
恢复之后,git stach drop
删除stach,可以用git stash apply stash@{0}
指定处理目标函数) -
协作开发
git remote -v
查看分支情况
git push origin master
推送分支到远程库
git push origin dev
(master 作为主分支,需要时刻与远程同步,dev 分支作为开发分支需要,与远程同步
git clone <url>
将远程分支下载到本地
git checkout -b dev origin/dev
将远程origin的dev分支到本地dev 上
git pull
失败需要进行链接分支git branch --set-upstream-to <branch-name> origin/<branch-name>
-
标签
git tag <name>
打标签默认使用HEAD(commit_id)
git log --pretty=oneline --abbrev-commit
查阅目标信息,找到版本号
git tag <name> <commit_id>
给目标commitid打上标签
git show <tagname>
查看目标标签信息
git tag
查看所有标签
git tag -d <tagname>
删除目标标签
git push origin <tagname>
将标签推送到远程
git push origin --tags
将所有未被推送的标签推送到远程
git push origin :refs/tags/<tagname>
删除目标远程标签 -
.gitignore 细节配置
忽略特殊文件,
Template
记住密码
ssh-keygen -t rsa -C "邮箱地址"
- 将生成的.ssh/rsa.pub文件的内容复制添加到码云上
- 进入项目仓库下的.git/config的[remote "origin"] ,修改远程连接属性为如将
https://gitee.com/southgnss_mozh/DemoTest
改为git@gitee.com:southgnss_mozh/DemoTest
冲突操作
主动选择需要保留的内容,替换到线上版本,在进行接下来的提交操作
子模块
#添加 git 子模块
git submodule add repourl
初次clone带有子模块的仓库如果想查看子模块的内容:
git submodule init
git submodule update
或者 git submodule update --init --recursive
# 更新子模块地址
vi .gitmodules #修改url地址
git submodule sync
然后提交更改即可。
# 删除子模块
删除 .gitsubmodule中对应submodule的条目
删除 .Git/config 中对应submodule的条目
git rm --cached {submodule_path} # submodule_path即子模块在仓库下的路径
git commit -m 'xxx'
git
C++ 基础学习
- 复习C++的基础语法,类型,定义,类的声明实现操作,文件读写与简单线程学习
- 学习C++本身抽象类,重载,重写相关知识
- 简单学习了STL 关于container容器的头文件(vector,list,queue,stack,set,array,stack)