首页
关于
Search
1
给你10个市场数据调研报告的免费下载网站!以后竞品数据就从这里找!
141 阅读
2
php接口优化 使用curl_multi_init批量请求
131 阅读
3
2024年备考系统架构设计师
102 阅读
4
《从菜鸟到大师之路 ElasticSearch 篇》
102 阅读
5
PHP 文件I/O
89 阅读
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
登录
Search
标签搜索
php函数
php语法
性能优化
安全
错误和异常处理
问题
vue
Composer
Session
缓存
框架
Swoole
api
并发
异步
正则表达式
php-fpm
mysql 索引
开发规范
协程
dafenqi
累计撰写
785
篇文章
累计收到
8
条评论
首页
栏目
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
副业
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
页面
关于
搜索到
785
篇与
的结果
2023-08-30
Linux 命令之systemd
Linux 命令之systemdsystemd介绍systemd是目前Linux系统上主要的系统守护进程管理工具,由于init一方面对于进程的管理是串行化的,容易出现阻塞情况,另一方面init也仅仅是执行启动脚本,并不能对服务本身进行更多的管理。所以从CentOS 7开始也由systemd取代了init作为默认的系统进程管理工具。systemd所管理的所有系统资源都称作Unit,通过systemd命令集可以方便的对这些Unit进行管理。比如systemctl、hostnamectl、timedatectl、localctl等命令,这些命令虽然改写了init时代用户的命令使用习惯(不再使用chkconfig、service等命令),但确实也提供了很大的便捷性。systemd特点1.最新系统都采用systemd管理(RedHat7,CentOS7,Ubuntu15...)2.CentOS7 支持开机并行启动服务,显著提高开机启动效率3.CentOS7关机只关闭正在运行的服务,而CentOS6,全部都关闭一次。4.CentOS7服务的启动与停止不再使用脚本进行管理,也就是/etc/init.d下不在有脚本。5.CentOS7使用systemd解决原有模式缺陷,比如原有service不会关闭程序产生的子进程。systemd语法systemctl [command] [unit](配置的应用名称) command可选项 · start:启动指定的unit systemctl start nginx · stop:关闭指定的unit systemctl stop nginx · restart:重启指定unit systemctl restart nginx · reload:重载指定unit systemctl reload nginx · enable:系统开机时自动启动指定unit,前提是配置文件中有相关配置 systemctl enable nginx · disable:开机时不自动运行指定unit systemctl disable nginx · status:查看指定unit当前运行状态 systemctl status nginxsystemd配置文件说明每一个Unit都需要有一个配置文件用于告知systemd对于服务的管理方式配置文件存放于/usr/lib/systemd/system/,设置开机启动后会在/etc/systemd/system目录建立软链接文件每个Unit的配置文件配置默认后缀名为.service在/usr/lib/systemd/system/目录中分为system和user两个目录,一般将开机不登陆就能运行的程序存在系统服务里,也就是/usr/lib/systemd/system配置文件使用方括号分成了多个部分,并且区分大小写systemd相关文件实战一、源码编译安装nginx 实现systemd管理控制安装nginx编译环境yum -y install gcc gcc-c++ openssl-devel pcre-devel gd-devel iproute net-tools telnet wget curl wget http://nginx.org/download/nginx-1.15.5.tar.gz tar zxf nginx-1.15.5.tar.gz && cd nginx-1.15.5 ./configure --prefix=/usr/local/nginx \ --with-http_ssl_module \ --with-http_stub_status_module make -j 4 && make install通用方式启动nginx/usr/local/nginx/sbin/nginx #启动 /usr/local/nginx/sbin/nginx -s reload #重启 /usr/local/nginx/sbin/nginx -s quit #关闭nginxsystemd 管理控制启动模式vim /usr/lib/systemd/system/nginx.service[Unit] Description=nginx After=network.target [Service] Type=forking ExecStart=/usr/local/nginx/sbin/nginx ExecReload=/usr/local/nginx/sbin/nginx -s reload ExecStop=/usr/local/nginx/sbin/nginx -s quit PrivateTmp=true [Install] WantedBy=multi-user.target参数详解systemctl restart nginx systemctl enable nginx systemctl stop nginx如图所示实现了systemd 管理控制nginx服务实战二、二进制安装tomcat 实现systemd管理控制安装java环境我已经将安装包打包到我的服务器上,也可以去官网下载wget 120.78.77.38/file/jdk-8u231-linux-x64.rpm wget 120.78.77.38/file/apache-tomcat-9.0.27.tar.gzrpm -ivh jdk-8u231-linux-x64.rpm #rpm直接安装jdk配置环境变量export JAVA_HOME=/usr/java/jdk1.8.0_231-amd64 export JRE_HOME=${JAVA_HOME}/jre export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib export JAVA_PATH=${JAVA_HOME}/bin:${JRE_HOME}/bin export PATH=${JAVA_HOME}/bin:$PATH 安装tomcattar -xf apache-tomcat-9.0.27 mv apache-tomcat-9.0.27 /usr/local/tomcat启动tomcatsh /usr/local/tomcat/bin/startup.sh #启动 sh /usr/local/tomcat/bin/shutdown.sh #关闭systemd管理控制启动[Unit] Description=tomcat server Wants=network-online.target After=network.target [Service] Type=forking WorkingDirectory=/home/dingding/service/tomcat/bin Environment="JAVA_HOME=/usr/java/jdk1.8.0_231-amd64" Environment="PATH=$JAVA_HOME/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin" Environment="CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar" ExecStart=/usr/local/tomcat/bin/startup.sh ExecStop=/usr/local/tomcat/bin/shutdown.sh Restart=on-failure [Install] WantedBy=multi-user.targetubuntu系统tomcat配置[Unit] Description=tomcat server Wants=network-online.target After=network.target [Service] Type=forking WorkingDirectory=/home/dingding/service/tomcat/bin UMask=0007 Environment="JAVA_HOME=/usr/local/jdk/jre" Environment=CATALINA_PID=/home/dingding/service/tomcat/temp/tomcat.pid Environment=CATALINA_HOME=/home/dingding/service/tomcat Environment=CATALINE_BASE=/home/dingding/service/tomcat ExecStart=/home/dingding/service/tomcat/bin/startup.sh ExecStop=/home/dingding/service/tomcat/bin/shutdown.sh User=dingding Group=dingding [Install] WantedBy=default.targetsystemctl restart tomcat #启动 systemctl enable tomcat #配置自启 systemctl stop tomcat #停止服务 systemctl status tomcat #检测状态 systemctl daemon-reload 重新加载配置以上两个实战nginx和tomcat程序中自带了启动停止脚本,如果启动得程序没有自带脚本则需要自己编写一个类似得启动停止脚本实战三、部署jar程序 实现systemd管理控制实际得项目中会有一些jar程序需要启动 如果手动启动则需要输入一大串命令 停止则需要杀掉进程来停止,很麻烦举一个实际启动得例子切换到jar目录下java -jar decode.jar -Dconfig=/usr/local/abc/application.properties编写一个启动脚本vim demo.sh#!/bin/bash # source /etc/profile jarName="abc-web.jar" workDir="/usr/local/abc" start(){ cd ${workDir} && java -jar ${jarName} --spring.profiles.active=prod --server.port=9630 >uams.log 2>&1 & } stop(){ ps -ef | grep -qP "(?<=-jar)\s+${jarName}" && kill $(ps -ef | grep -P "(?<=-jar)\s+${jarName}" | awk '{print $2}') } case $1 in start) start ;; stop) stop ;; restart) stop start ;; esac编写 systemd配置文件vim /usr/lib/systemd/system/abc.service[Unit] Description=uams server Wants=network-online.target After=network.target [Service] Type=forking WorkingDirectory=/usr/local/abc/ ExecStart=/bin/bash uams.sh start ExecStop=/bin/bash uams.sh stop ExecReload=/bin/bash uams.sh restart Restart=on-failure [Install] WantedBy=multi-user.target启动abc服务systemctl restart abc #启动 systemctl enable abc #配置自启 systemctl stop abc #停止服务 systemctl status abc #检测状态高级写法还有一种更高级的写法,在service中直接定义环境变量和脚本cat /lib/systemd/system/yuxin-house.service[Unit] Description=yuxin house Wants=network-online.target After=network.target [Service] Type=simple WorkingDirectory=/home/dingding/yuxin-house UMask=0007 Environment=PATH=/usr/local/jdk-11/bin:/usr/local/jdk-11/jre/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin Environment=JAVA_HOME=/usr/local/jdk-11 Environment=CLASSPATH=/usr/local/jdk-11/lib:/usr/local/jdk-11/jre/lib:/usr/local/jdk-11/lib/tools.jar:/usr/local/jdk/lib:/usr/local/jdk/jre/lib:/usr/local/jdk/lib/tools.jar:/usr/local/jdk-11/lib:/usr/local/jdk-11/jre/lib:/usr/local/jdk-11/lib/tools.jar ExecStart=/usr/local/jdk-11/bin/java -XX:+UseG1GC -XX:MaxGCPauseMillis=150 -Xms125M -Xmx512M -jar yuxin-house.jar --spring.profiles.active=test ExecStop=/bin/kill -9 $MAINPID Restart=on-failure StartLimitBurst=4 User=dingding Group=dingding [Install] WantedBy=multi-user.target
2023年08月30日
16 阅读
0 评论
0 点赞
2023-08-30
Linux 命令之scp
Linux 命令之scp
2023年08月30日
10 阅读
0 评论
0 点赞
2023-08-30
Linux 命令之crontab
Linux 命令之crontab命令简介在服务器安装好系统及相关服务之后,对于系统的配置、服务的配置、数据的管理以及服务器的操作权限管理就变的尤为重要。因为,涉及到服务器的各项安全(如:登录、操作)。crontab 命令用来打开 cron 表进行编辑。定时任务:顾名思义,就是定期执行某项操作或者某种行为。像Windows系统同样它也有定时任务服务。在Linux系统中,crond是Linux系统中用来定期执行命令、脚本或指定程序的一种服务。定时任务一般有以下两种用途:1、系统自身定期执行的操作或任务(如:日志轮询)。2、用户定期执行的操作或任务(如:定时更新同步数据、重要数据备份等)。Linux下的任务调度分为两类:系统任务调度和用户任务调度系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等。在/etc/目录下有一个crontab文件,这个就是系统任务调度的配置文件。/etc/crontab 文件内容如下[root@centos7 ~]# cat /etc/crontab SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root # For details see man 4 crontabs # Example of job definition: # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .------- month (1 - 12) OR jan,feb,mar,apr ... # | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat # | | | | | # * * * * * user-name command to be executed从上机的配置文件,可以看出系统定时任务格式/etc/crontab分为6段,以空格分隔。前5段为时间格式,第6段是所需执行的命令。详细的说明:minute #分钟,可以是从0到59之间的任何整数hour #小时,可以是从0到23之间的任何整数day #日期,可以是从1到31之间的任何整数month #月份,可以是从1到12之间的任何整数week #星期,可以是从0到7之间的任何整数,这里的0或7代表星期日command #执行的命令,可以是系统命令,也可以是自己编写的脚本文件在上述的配置字段中,还会使用到下面的特殊字符*(星号) #表示所有值。比如在第一段中如果使用*,则表示在满足其他条件的同时每分钟都执行后面的命令操作。,(逗号) #用逗号分隔的值表示指定的一个范围。比如在第四段使用1,3,5,7,则表示在第1,3,5,7月的含义。—(中杠) #表示一个范围。比如在第二段使用0-8,则表示0点到8点这一区间范围。/(正斜线) #表示一个时间的间隔频率。比如在第一段使用*/5,则表示每间隔5分钟的含义。语法格式crontab [-u user] file crontab [-u user] [-l | -r | -e] [-i] [-s]选项说明-e #编辑该用户的计时器-l #列出该用户的计时器-r #删除该用户的计时器-u<用户名称> #指定要设定计时器的用户名称-i:在删除定时任务列表时进行确认提示-s:显示该用户的下一个定时任务执行时间定时任务书写与配置书写定任务规范在日常实际生产、测试环境中,书写定时任务是需要遵守一定的规范、规则的。笔者根据自己实际生产环境书写经验,总结如下:1、书写定时任务时必须对每一行或一段加上注释信息。2、如里是以shell脚本执行的任务,在最前面加上解释/bin/sh。3、对于执行脚本的定时任务,需在其结尾加上>/dev/null 2>&1将一些不必要的输出信息重定向到空,也就是不输出不需要的信息。4、使用系统或服务命令要使用绝对路径,再写到脚本,最后将脚本写进定时任务中。5、规范使用目录(如定时任务执行的脚本目录设置成/server/cron_scripts)。2)定时任务配置实际生产、测试环境,对于定时任务的配置也是需要有一定操作规范的,具体如下:1、对于执行命令的形式的定时任务,需要先测试命令执行情况,确认无误后将执行的命令写进脚本。2、对于脚本形式的定时任务,首先就是需要调试脚本的整体执行情况,然后使用规范目录路径写进定时任务。3、对于生产环境的定时任务操作,必须在测试环境进行反复测试,确认无误后再应用到实际生产环境中,然后在定时任务执行后人工进行检查执行情况。对于定时任务的具体实例及各类操作,可参考官方文档说明。读者也可在自己的实验环境进行书写、配置,本章节就不做过多赘述。应用举例查看当前登录用户下的定时任务情况[root@centos7 ~]# crontab -l no crontab for root每小时的第5和第15分钟执行5,15 * * * * command_name在上午9点到11点的第5和第15分钟执行5,15 9-11 * * * command_name每隔3天的上午9点到11点的第5和第15分钟执行5,15 9-11 */3 * * command_name每个星期一的上午9点到11点的第5和第15分钟执行5,15 9-11 * * 1 command_name每月1、11、21日的14:45重启httpd45 14 1,11,21 * * /etc/init.d/httpd restart每周六、周日的1:10重启smb10 1 * * 6,0 /etc/init.d/httpd restart每小时执行/etc/scripts/test.sh这个脚本01 * * * * /etc/scripts/test.sh拓展在Linux中,设置定时任务的方法有多种。以下是常见的几种方法及其使用说明:使用crontab命令:使用crontab -e命令编辑当前用户的cron表。在打开的文件中,每一行代表一个定时任务,使用cron表达式来指定任务执行的时间。例如,以下示例将在每天的上午9点运行脚本/path/to/script.sh:0 9 * * * /path/to/script.sh保存并关闭文件后,cron会自动加载更新后的cron表。使用crontab -l命令查看当前用户的cron表。编辑系统级的/etc/crontab文件:使用文本编辑器打开/etc/crontab文件。每一行代表一个定时任务,使用cron表达式来指定任务执行的时间和要执行的命令。例如,以下示例将在每天的上午9点运行脚本/path/to/script.sh:0 9 * * * root /path/to/script.sh保存并关闭文件后,cron会自动加载更新后的cron表。使用crontab -l命令查看当前用户的cron表。使用/etc/cron.d/目录:在/etc/cron.d/目录中创建一个文件,文件名可以自定义,但不要包含.或/字符。文件内容格式与crontab相同,使用cron表达式来指定任务执行的时间和要执行的命令。例如,创建一个名为mytask的文件,内容如下:0 9 * * * root /path/to/script.sh保存文件后,cron会自动加载更新后的cron表。使用crontab -l命令查看当前用户的cron表。使用systemd的定时器:创建一个.timer文件,用于配置定时器的触发条件和要执行的任务。创建一个.service文件,用于定义要执行的任务的具体命令和其他设置。将这两个文件放置在/etc/systemd/system/目录中。运行systemctl daemon-reload命令,以重新加载systemd配置。使用systemctl start mytimer.timer命令启动定时器。使用systemctl enable mytimer.timer命令将定时器设置为开机启动。使用systemctl status mytimer.timer命令查看定时器的状态。这些方法之间的区别主要在于使用的工具和配置方式。crontab命令和/etc/crontab文件是传统的cron工具,适用于简单的定时任务。/etc/cron.d/目录允许将定时任务分散到多个文件中,更灵活。使用systemd的定时器提供了更精确的时间控制和更高级的功能,适用于需要更复杂任务调度的场景。选择最好的方法取决于您的具体需求和使用场景。如果只需要为当前用户设置定时任务,使用crontab命令是最简单和常见的方法。如果需要为整个系统或其他用户设置定时任务,可以选择编辑/etc/crontab文件或使用/etc/cron.d/目录。如果您使用的是systemd作为初始化系统,并且需要更高级的功能和集成,可以考虑使用systemd的定时器。请根据您的具体需求和系统配置选择最适合您的方式,并参考相关文档以获取更详细的使用说明。systemd进程管理工具详细教程请看这:Linux 命令之systemd
2023年08月30日
21 阅读
0 评论
0 点赞
2023-08-30
Git学习笔记
Git学习笔记Git 简介Git 是一个 开源的分布式版本控制系统。什么是版本控制?版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。什么是分布式版本控制系统?介绍分布式版本控制系统前,有必要先了解一下 传统的集中式版本控制系统。 集中化的版本控制系统 ,诸如 CVS,Subversion 等,都有一个 单一的集中管理的服务器 ,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器, 取出最新的文件或者提交更新。 这么做最 显而易见的缺点是中央服务器的单点故障。 如果宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。要是中央服务器的磁盘发生故障,碰巧没做备份,或者备份不够及时,就会有丢失数据的风险。最坏的情况是彻底丢失整个项目的所有历史更改记录。分布式版本控制系统的客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来。 这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份。可参考: Git 从入门到精通Git vs SVNGit 和 SVN 孰优孰好,每个人有不同的体验。Git是分布式的,SVN是集中式的这是 Git 和 SVN 最大的区别。若能掌握这个概念,两者区别基本搞懂大半。因为 Git 是分布式的,所以 Git 支持离线工作,在本地可以进行很多操作,包括接下来将要重磅推出的分支功能。而 SVN 必须联网才能正常工作。Git复杂概念多,SVN简单易上手所有同时掌握 Git 和 SVN 的开发者都必须承认,Git 的命令实在太多了,日常工作需要掌握add,commit,status,fetch,push,rebase等,若要熟练掌握,还必须掌握rebase和merge的区别,fetch和pull的区别等,除此之外,还有cherry-pick,submodule,stash等功能,仅是这些名词听着都很绕。在易用性这方面,SVN对于新手来说会更有好一些。但是从另外一方面看,Git 命令多意味着功能多,若我们能掌握大部分 Git 的功能,体会到其中的奥妙,会发现再也回不去 SVN 的时代了。Git分支廉价,SVN分支昂贵在版本管理里,分支是很常使用的功能。在发布版本前,需要发布分支,进行大需求开发,需要 feature 分支,大团队还会有开发分支,稳定分支等。在大团队开发过程中,常常存在创建分支,切换分支的求。Git 分支是指针指向某次提交,而 SVN 分支是拷贝的目录。这个特性使 Git 的分支切换非常迅速,并且创建成本非常低。而且 Git 有本地分支,SVN 无本地分支。在实际开发过程中,经常会遇到有些代码没写完,但是需紧急处理其他问题,若我们使用 Git,便可以创建本地分支存储没写完的代码,待问题处理完后,再回到本地分支继续完成代码。更多关注Git与Svn的比较请参阅: 通俗易懂|用好Git 和 SVN ,轻松驾驭版本管理Git 工作原理文字不好理解,请看 图文详解 Git 工作原理Git 安装Debian/Ubuntu 环境安装如果你使用的系统是 Debian/Ubuntu , 安装命令为:$ apt-get install libcurl4-gnutls-dev libexpat1-dev gettext \ > libz-dev libssl-dev $ apt-get install git-core $ git --version git version 1.8.1.2Centos/RedHat 环境安装如果你使用的系统是 Centos/RedHat ,安装命令为:$ yum install curl-devel expat-devel gettext-devel \ > openssl-devel zlib-devel $ yum -y install git-core $ git --version git version 1.7.1Windows 环境安装在 Git 官方下载地址下载 exe 安装包。按照安装向导安装即可。建议安装 Git Bash 这个 git 的命令行工具。Mac 环境安装在 Git 官方下载地址下载 mac 安装包。按照安装向导安装即可。Git配置Git 自带一个 git config 的工具来帮助设置控制 Git 外观和行为的配置变量。这些变量存储在三个不同的位置:/etc/gitconfig 文件: 包含系统上每一个用户及他们仓库的通用配置。如果使用带有 --system 选项的 git config 时,它会从此文件读写配置变量。\~/.gitconfig 或 \~/.config/git/config 文件:只针对当前用户。可以传递 --global 选项让 Git 读写此文件。当前使用仓库的 Git 目录中的 config 文件(就是 .git/config):针对该仓库。每一个级别覆盖上一级别的配置,所以 .git/config 的配置变量会覆盖 /etc/gitconfig 中的配置变量。在 Windows 系统中,Git 会查找 $HOME 目录下(一般情况下是 C:\Users\$USER)的 .gitconfig 文件。Git 同样也会寻找 /etc/gitconfig 文件,但只限于 MSys 的根目录下,即安装 Git 时所选的目标位置。Git 基本概念版本库当你一个项目到本地或创建一个 git 项目, 项目目录下会有一个隐藏的 .git 子目录。这个目录是 git 用来跟踪管理版本库的 ,千万不要手动修改。哈希值Git 中所有数据在存储前都计算校验和,然后以校验和来引用。这意味着不可能在 Git 不知情时更改任何文件内容或目录内容。这个功能建构在 Git 底层,是构成 Git 哲学不可或缺的部分。若你在传送过程中丢失信息或损坏文件,Git 就能发现。 Git 用以计算校验和的机制叫做 SHA-1 散列(hash,哈希) 。这是一个由 40 个十六进制字符(0-9 和 a-f)组成字符串,基于 Git 中文件的内容或目录结构计算出来。SHA-1 哈希看起来是这样:24b9da6552252987aa493b52f8696cd6d3b00373Git 中使用这种哈希值的情况很多,你将经常看到这种哈希值。实际上, Git 数据库中保存的信息都是以文件内容的哈希值来索引,而不是文件名。文件状态在 GIt 中,你的文件可能会处于 三种状态 之一:已修改(modified) - 已修改表示修改了文件,但还没保存到数据库中。已暂存(staged) - 已暂存表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。已提交(committed) - 已提交表示数据已经安全的保存在本地数据库中。工作区域与文件状态对应的, 不同状态的文件在 Git 中处于不同的工作区域 。工作区(working) - 当你 git clone 一个项目到本地,相当于在本地克隆了项目的一个副本。工作区是对项目的某个版本独立提取出来的内容。这些从 Git 仓库的压缩数据库中提取出来的文件,放在磁盘上供你使用或修改。暂存区(staging)- 暂存区是一个文件,保存了下次将提交的文件列表信息,一般在 Git 仓库目录中。有时候也被称作 `‘索引’',不过一般说法还是叫暂存区。本地仓库(local) - 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 本地仓库。远程仓库(remote) - 以上几个工作区都是在本地。为了让别人可以看到你的修改,你需要将你的更新推送到远程仓库。同理,如果你想同步别人的修改,你需要从远程仓库拉取更新。分支(Branch)分支是为了将修改记录的整个流程分开存储,让分开的分支不受其它分支的影响,所以在同一个数据库里可以同时进行多个不同的修改 主分支(Master)前面提到过 master 是 Git 为我们自动创建的第一个分支,也叫主分支,其它分支开发完成后都要合并到 master 标签(Tag)标签是用于标记特定的点或提交的历史,通常会用来标记发布版本的名称或版本号(如:publish/0.0.1),虽然标签看起来有点像分支,但打上标签的提交是固定的,不能随意的改动,HEADHEAD 指向的就是当前分支的最新提交图片 以上概念了解的差不多,那就可以继续往下看。Git 命令创建仓库克隆一个已创建的仓库:通过 SSH$ git clone ssh://user@domain.com/repo.git通过 HTTP$ git clone http://domain.com/user/repo.git创建一个新的本地仓库$ git init添加修改添加修改到暂存区把指定文件添加到暂存区$ git add xxx把当前所有修改添加到暂存区$ git add .把所有修改添加到暂存区$ git add -A提交修改到本地仓库提交本地的所有修改$ git commit -a提交之前已标记的变化$ git commit附加消息提交$ git commit -m 'commit message'储藏有时,我们需要在同一个项目的不同分支上工作。当需要切换分支时,偏偏本地的工作还没有完成,此时,提交修改显得不严谨,但是不提交代码又无法切换分支。这时, 你可以使用 git stash 将本地的修改内容作为草稿储藏起来。 官方称之为 储藏 ,但我个人更喜欢称之为 存草稿 。1. 将修改作为当前分支的草稿保存$ git stash2. 查看草稿列表$ git stash list stash@{0}: WIP on master: 6fae349 :memo: Writing docs.3.1 删除草稿$ git stash drop stash@{0}3.2 读取草稿$ git stash apply stash@{0}撤销修改撤销本地修改移除缓存区的所有文件(i.e. 撤销上次git add)$ git reset HEAD将HEAD重置到上一次提交的版本,并将之后的修改标记为未添加到缓存区的修改$ git reset <commit>将HEAD重置到上一次提交的版本,并保留未提交的本地修改$ git reset --keep <commit>放弃工作目录下的所有修改$ git reset --hard HEAD将HEAD重置到指定的版本,并抛弃该版本之后的所有修改$ git reset --hard <commit-hash>用远端分支强制覆盖本地分支$ git reset --hard <remote/branch> e.g., upstream/master, origin/my-feature放弃某个文件的所有本地修改$ git checkout HEAD <file>删除添加.gitignore文件前错误提交的文件$ git rm -r --cached . $ git add . $ git commit -m "remove xyz file"撤销远程修改(创建一个新的提交,并回滚到指定版本)$ git revert <commit-hash>彻底删除指定版本:执行下面命令后,commit-hash 提交后的记录都会被彻底删除,使用需谨慎$ git reset --hard <commit-hash> $ git push -f更新与推送更新下载远程端版本,但不合并到HEAD中$ git fetch <remote>将远程端版本合并到本地版本中$ git pull origin master以rebase方式将远端分支与本地合并$ git pull --rebase <remote> <branch>推送将本地版本推送到远程端$ git push remote <remote> <branch>删除远程端分支$ git push <remote> :<branch> (since Git v1.5.0) $ git push <remote> --delete <branch> (since Git v1.7.0)发布标签$ git push --tags查看信息显示工作路径下已修改的文件$ git status显示与上次提交版本文件的不同$ git diff显示提交历史从最新提交开始,显示所有的提交记录(显示hash, 作者信息,提交的标题和时间)$ git log显示某个用户的所有提交$ git log --author="username"显示某个文件的所有修改$ git log -p <file>显示搜索内容从当前目录的所有文件中查找文本内容$ git grep "Hello"在某一版本中搜索文本$ git grep "Hello" v2.5分支增删查分支列出所有的分支$ git branch列出所有的远端分支$ git branch -r基于当前分支创建新分支$ git branch <new-branch>基于远程分支创建新的可追溯的分支$ git branch --track <new-branch> <remote-branch>删除本地分支$ git branch -d <branch>强制删除本地分支,将会丢失未合并的修改$ git branch -D <branch>切换分支切换分支$ git checkout <branch>创建并切换到新分支$ git checkout -b <branch>标签给当前版本打标签$ git tag <tag-name>给当前版本打标签并附加消息$ git tag -a <tag-name>合并与重置merge 与 rebase 虽然是 git 常用功能,但是强烈建议不要使用 git 命令来完成这项工作。 因为如果出现代码冲突,在没有代码比对工具的情况下,实在太艰难了。你可以考虑使用各种 Git GUI 工具。合并将分支合并到当前HEAD中$ git merge <branch>重置将当前HEAD版本重置到分支中,请勿重置已发布的提交$ git rebase <branch>更多命令参考: 三年 Git 使用心得 & 常见问题整理Git 分支开发Git 是目前最流行的源代码管理工具。 为规范开发,保持代码提交记录以及 git 分支结构清晰,方便后续维护以及规范 git 的相关操作。分支命名1、master 分支master 为 主分支 ,也是用于部署 生产环境 的分支,确保master分支稳定性, master 分支一般由develop以及hotfix分支合并,任何时间都不能直接修改代码2、develop 分支develop 为 开发分支 , 始终保持最新完成以及bug修复后的代码 ,一般开发的新功能时,feature分支都是基于develop分支下创建的。feature 分支开发 新功能 时,以develop为基础创建feature分支。分支命名: feature/ 开头的为特性分支, 命名规则: feature/user_module、 feature/cart_modulerelease 分支release 为 预上线分支 ,发布提测阶段,会release分支代码为基准提测。当有一组feature开发完成,首先会合并到develop分支,进入提测时会创建release分支。如果测试过程中若存在bug需要修复,则直接由开发者在release分支修复并提交。当测试完成之后,合并release分支到master和develop分支,此时master为最新代码,用作上线。hotfix 分支分支命名: hotfix/ 开头的为 修复分支 ,它的命名规则与feature分支类似。线上出现紧急问题时,需要及时修复,以master分支为基线,创建hotfix分支,修复完成后,需要合并到master分支和develop分支更多开发规范请参阅: 全网最全的 Git 分支开发规范手册 | 掌握这10条规范,轻松搞定Git! 拓展:Git这些高级用法,喜欢就拿去用!Git 提交规范为什么需要规范?无规矩不成方圆,编程也一样。如果你有一个项目,从始至终都是自己写,那么你想怎么写都可以,没有人可以干预你。可是如果在团队协作中,大家都张扬个性,那么代码将会是一团糟,好好的项目就被糟践了。不管是 开发还是日后维护 ,都将是灾难。这时候,有人提出了何不统一标准,大家都按照这个标准来。于是 ESLint,JSHint 等代码工具如雨后春笋般涌现,成为了项目构建的必备良品。Git Commit 规范 可能并没有那么夸张,但如果你在版本回退的时候看到一大段糟心的 Commit,恐怕会懊恼不已吧。所以,严格遵守规范,利人利己。具体请参阅: 你可能会忽略的 Git 提交规范Git使用技巧只有在遇到问题的时候,才体会到技巧带来的好处!常见企业工作流程(Git Workflow)当项目需要多人共同开发时,规范工作流程就变得越来越重要。合适的工作流程能让多人协同开发更加顺利和高效。目前主流的Git工作流程有三种:Git Flow(版本发布)GitHub Flow(持续发布)GitLab Flow(持续发布、版本发布)拓展:一文弄懂 Gitflow、Github flow、Gitlab flow 的工作流Git Flow主干分支稳定分支开发分支补丁分支修改分支Github Flow创建分支添加提交提交 PR 请求讨论和评估代码部署检测合并代码Gitlab Flow带生产分支带环境分支带发布分支日常使用最佳实践总结日常工作中应该遵循的 Git 使用方式 和方法!使用命令行代替图形化界面使用命令行来操作,简洁且效率高提交应该尽可能的表述提交修改内容区分 subject 和 body 内容,使用空行隔开subject 一般不超过 50 个字符body 每一行的长度控制在 72 个字符subject 结尾不需要使用句号或者点号结尾body 用来详细解释此次提交具体做了什么使用 .gitignore 文件来排除无用文件可使用模板文件,然后根据项目实际进行修改基于分支或 fork 的开发模式不要直接在主干分支上面进行开发在新建的分支上进行功能的开发和问题的修复使用 release 分支和 tag 标记进行版本管理使用 release 分支发布代码和版本维护(release/1.32)使用 tag 来标记版本(A-大feature功能.B-小feature功能.C-只修bug)常用命令汇总整理日常使用只要记住 6 个命令 就可以了。工作区 -> 暂存区$ git add <file/dir>暂存区 -> 本地仓库$ git commit -m "some info"本地仓库 -> 远程仓库$ git push origin master # 本地master分支推送到远程origin仓库 工作区 <- 暂存区$ git checkout -- <file> # 暂存区文件内容覆盖工作区文件内容暂存区 <- 本地仓库$ git reset HEAD <file> # 本地仓库文件内容覆盖暂存区文件内容本地仓库 <- 远程仓库$ git clone <git_url> # 克隆远程仓库 $ git fetch upstream master # 拉取远程代码到本地但不应用在当前分支 $ git pull upstream master # 拉取远程代码到本地但应用在当前分支 $ git pull --rebase upstream master # 如果平时使用rebase合并代码则加上工作区 <- 本地仓库$ git reset <commit> # 本地仓库覆盖到工作区(保存回退文件内容修改) $ git reset --mixed <commit> # 本地仓库覆盖到工作区(保存回退文件内容修改) $ git reset --soft <commit> # 本地仓库覆盖到工作区(保留修改并加到暂存区) $ git reset --hard <commit> # 本地仓库覆盖到工作区(不保留修改直接删除掉)更多关于Git的使用技巧介绍请查阅:学会这 11 条,你离 Git 大神就不远了!
2023年08月30日
67 阅读
0 评论
0 点赞
2023-08-30
Kafka是什么,主要应用在什么场景
Kafka是什么,主要应用在什么场景
2023年08月30日
16 阅读
0 评论
0 点赞
1
...
63
64
65
...
157