1、创建仓库
data:image/s3,"s3://crabby-images/3e37d/3e37d821213ff81969f668f456077f7d36d78d90" alt=""
data:image/s3,"s3://crabby-images/325d4/325d47c817df308b81406633756304a9ca125471" alt=""
2、克隆仓库到本地(首次拉取需要输入用户名和密码,用户名用邮箱,密码用登录gitee的密码,后面配置密钥后可以直接clone)
在命令行输出两行指令配置git才能克隆:
username:gitee账号名
useremail:gitee账号绑定的邮箱
data:image/s3,"s3://crabby-images/4151c/4151c8fdc43ee296587979c62c680c5eca99a4ae" alt=""
data:image/s3,"s3://crabby-images/ab224/ab2249c6a587ddc0b6f60a6c694d95a2726eca0e" alt=""
data:image/s3,"s3://crabby-images/77d82/77d82860ba944a7df9f90bab4a6d893d5396d153" alt=""
进入拉取下来的工程目录:
data:image/s3,"s3://crabby-images/dbcb0/dbcb073f755dcce5a6a5b748da844a52dafc2b19" alt=""
使用ll命令查看.git
data:image/s3,"s3://crabby-images/7a0d2/7a0d247936a4b1190b17aa6e7b7f6b673e5801e5" alt=""
3、git的设计原理:
index:暂存区
objects:版本库
data:image/s3,"s3://crabby-images/c0749/c07494381dc0e3b3194b563b03c947aa5ffd36d5" alt=""
data:image/s3,"s3://crabby-images/17ddc/17ddc4505a7e9d1f59ac15c3b2311056d0166ff0" alt=""
4、git status:获取版本状态,该命令不能再隐藏文件.git中使用
data:image/s3,"s3://crabby-images/f0ed7/f0ed758f894116e3d2dfd533986141b8da96ee73" alt=""
添加了文件的状态:
添加了文件到版本库的状态:
data:image/s3,"s3://crabby-images/61a5a/61a5a25c3f825064d61735d9c37282de2f2d1397" alt=""
5、推送更新仓库过程
(1)添加文件到暂存区:git add filename
data:image/s3,"s3://crabby-images/7a224/7a22448f7fe2c4056a9f60eb44a44eb857bccb8f" alt=""
(2)添加暂存区到版本库:git commit -m "添加说明" (建议格式固定:添加人员:操作描述)
data:image/s3,"s3://crabby-images/44339/44339fe5b0e4bb9b98987ecb1c14ef35fc8b0da4" alt=""
(3)推送文件到远程仓库:git push origin master
origin:远程仓库地址
data:image/s3,"s3://crabby-images/7fafd/7fafdd6394e69415f9ffaa78e0cc376b9b69dff4" alt=""
master:仓库分支名
data:image/s3,"s3://crabby-images/b4691/b4691e30c016b8487ed59e2ae96be99f89ce9ea9" alt=""
cd .git/
vim config
6、添加开发者协作
管理--》仓库成员管理--》开发者--》邀请
data:image/s3,"s3://crabby-images/3a84b/3a84b59814a25d156852e4964cf3c1c4b9ae3787" alt=""
添加公钥:
进入Linux家目录使用ssh-keygen -t -rsa -c "公钥标记"
data:image/s3,"s3://crabby-images/bd63c/bd63ceb8eac5b9e4ed2ac96fe4ad6dcebf9a0198" alt=""
cd 到.ssh/ 文件夹下可以看到生成的公钥和私钥;
pub后缀表示公钥;
data:image/s3,"s3://crabby-images/9a295/9a29526a2aa83979cb17d493c0a542f048b5ac0d" alt=""
使用cat 查看公钥内容并赋值到仓库的公钥添加上;
data:image/s3,"s3://crabby-images/fbcdf/fbcdf6da80fc504f3d6d551727a9c821fd3f57e3" alt=""
data:image/s3,"s3://crabby-images/24c17/24c17c4f99604970526e1c6a03b25cfc4199cb2d" alt=""
非仓库管理源获取该仓库内容需要用ssh:可以看提示配置
data:image/s3,"s3://crabby-images/536e3/536e3d0791df5034260ecc5a451b97e489000399" alt=""
git reflog于记录本地仓库的 HEAD 和分支引用(branch references)的变动历史
data:image/s3,"s3://crabby-images/bb1bd/bb1bd4c3da63ea2469fc67473d862bfc4f8c374c" alt=""
误删回滚:
1、在git add 之前删除 用git checkout -- .(git restore可以替代但是在未提交之前,暂未尝试成功;)
data:image/s3,"s3://crabby-images/e689f/e689ff47185ded955b9533c8e7b64ca78bbc8b28" alt=""
2、git add 之后 在 git commit 之前用 git restore 撤销修改;
data:image/s3,"s3://crabby-images/6c432/6c432ee0ec4f6d511d2d9b57dbbe517bc2727588" alt=""
data:image/s3,"s3://crabby-images/60332/6033204c8f42980174cacc6a43a6b23cd42dcd20" alt=""
data:image/s3,"s3://crabby-images/57c49/57c49734ba88fa8077cc5fae60ef8e275de8c178" alt=""
3、在git commit 之后删除可以通过git reset --hard 版本号前几个字符进行回滚
data:image/s3,"s3://crabby-images/cf6d8/cf6d85fe878957962841756fd60f798764157fed" alt=""
data:image/s3,"s3://crabby-images/f1fd0/f1fd0273101357028b298b0b577cd384df38d881" alt=""
data:image/s3,"s3://crabby-images/92b32/92b32dcba8d0aa5364bdb69e7e1802b6e5c1e4d3" alt=""
1. 创建仓库
- 在Gitee、GitHub等Git托管平台上创建一个新的仓库。通常包括填写仓库名称、描述、是否公开等信息。
2. 克隆仓库到本地
首次克隆仓库时,可能需要在命令行中输入用户名(使用邮箱格式)和密码(登录Gitee或GitHub的密码)。为了避免每次都需要输入密码,可以配置SSH密钥。
配置Git用户信息(尽管这与克隆仓库无直接关系,但通常在开始使用Git前进行):
|---|-------------------------------------------------|
| |git config --global user.name "gitee账号名"
|
| |git config --global user.email "gitee账号绑定的邮箱"
|克隆仓库命令:
|---|---------------------------------------|
| |git clone git@gitee.com:用户名/仓库名.git
|或使用HTTPS方式(首次可能需要输入用户名和密码):
|---|-------------------------------------------|
| |git clone https://gitee.com/用户名/仓库名.git
|进入仓库目录,并使用
ll
(或ls -l
)命令查看文件,包括.git
目录(通常是隐藏的)。3. Git的设计原理
- Index(暂存区):暂存更改的文件,准备提交到版本库中。
- Objects(版本库):存储实际的文件内容和Git的历史记录。
4.
git status
- 用于获取当前仓库的状态,包括哪些文件被修改了、哪些文件是新添加的、哪些文件被暂存了等。
- 添加了文件的状态 :
git status
会显示新文件未被跟踪(untracked)。- 添加了文件到版本库的状态:文件会显示为已暂存(staged)或已提交(committed)。
5. 推送更新仓库过程
添加文件到暂存区:
|---|--------------------|
| |git add filename
|添加暂存区到版本库:
|---|-------------------------------------------|
| |git commit -m "添加说明" # 例如:"张三: 添加了新功能X"
|推送文件到远程仓库:
|---|------------------------------------------|
| |git push origin master # 或者其他分支名,如main
|注意:随着Git的发展,
master
分支可能已被重命名为main
。6. 添加开发者协作
在Gitee等平台上,通过"管理"->"仓库成员管理"->"开发者"->"邀请"来添加协作者。
添加公钥:
在Linux上生成SSH密钥对(如果还没有的话):
|---|---------------------------------------|
| |ssh-keygen -t rsa -b 4096 -C "你的邮箱"
|将生成的公钥(
.ssh/id_rsa.pub
文件的内容)添加到Gitee等平台的SSH公钥设置中。7. 误删回滚
在
git add
之前删除:|---|---------------------------------------------------|
| |git checkout -- . # 或者 git restore .(Git 2.23+)
|在
git add
之后,git commit
之前撤销修改:|---|----------------------------------------------------------------|
| |git restore filename # 或者 git checkout -- filename(较旧的Git版本)
|在
git commit
之后删除或回滚:|---|---------------------------------------------------------------|
| |git reset --hard <commit-id> # <commit-id>可以是提交的完整哈希值的前几个字符
|8.
git reflog
- 用于记录本地仓库的HEAD和分支引用的变动历史。当你不确定何时或如何进行了某些更改时,这非常有用。
通过遵循这些规范,可以更有效地使用Git进行版本控制和团队协作。