搭建自己的repo server极简入门
这篇文章主要作为一个学习笔记,同时也希望可以帮助到其他有需要的朋友首先感谢如下几篇文章的指导:
http://blog.csdn.net/hansel/article/details/9798189
http://blog.csdn.net/lb5761311/article/details/47723455
http://bbs.mfunz.com/thread-1015705-1-1.html
http://blog.csdn.net/sunweizhong1024/article/details/8055372
http://blog.csdn.net/itleaks/article/details/30021395?utm_source=tuicool&utm_medium=referral
正文 -- repo完整安装及项目同步
1. 下载repo bootstrap(repo的启动文件,用于安装完整的repo)
- git clone git://git.omapzoom.org/git-repo.git
- ./git-repo/repo
2. 安装repo bootstrap
a. 创建本地repo
- mkdir ~/bin/
- cp ./git-repo/repo ~/bin/
b. 设置环境变量:
- vi ~/.profile
- if [ -d "$HOME/bin" ] ; then
- PATH="$HOME/bin:$PATH"
- fi
c. 使环境变量生效
- source ~/.profile
3. patch repo bootstrap
- vi ~/bin/repo
- -- REPO_URL = 'https://gerrit.googlesource.com/git-repo'
- ++ REPO_URL = 'git://codeaurora.org/tools/repo.git'
- fatal: Cannot get https://gerrit.googlesource.com/git-repo/clone.bundle
- fatal: error [Errno 101] Network is unreachable
4. 创建项目manifest清单,repo会以manifest中的配置来同步项目
a. 在server上创建manifest.git空仓库,在此以如下remote url地址为例:
- cd manifest.git
- git remote -v
- origin git:manifest (fetch)
- origin git:manifest (push)
b. 在客户端上clone manifest仓库
- git clone git:manifest
c. 创建default.xml文件,repo默认会以manifest仓库的default.xml为配置文件
- cd manifest
- vi default.xml
-
- fetch="git:"
- review="https://android-review.googlesource.com/" />
- remote="origin"
- sync-j="4" />
-
manifest配置分为三大部分:remote default 以及 project,分别进行讲解
remote:
指代同步项目的一个server地址(可有多个remote)
name为一个唯一标识的名字
fetch为url的前缀,在我们的例子当中,仓库路径一概都是git:XXX,所以前缀就是"git:"
review暂时可以不予考虑,以例子中的为准
default:
指代同步项目使用的默认server配置:
revision指代git分支的名字
remote指代使用的remote server
sync-j表示同步项目时并行个数
project:
指代同步项目的git仓库,这里假设我们有一个git:test的仓库(可以有多个)
name就是git仓库名test
path就是设置仓库存放在repo project的哪个目录下,这里就直接设置为存放在repo project子目录的test中
d. 同步default.xml的修改至服务器
- git add default.xml
- git commit -m "udpate default.xml for repo sync test"
- git push origin master
5. 安装完整版repo
a. 先创建并进入一个自定义目录:
- mkdir test-project
- cd test-project
b. 执行如下repo命令,用于初始化repo,并且指定了mainfest项目清单
- repo init -u git:manifest
c. 执行完后,先会有如下log,这里才是真正的clone了完整版的repo:
- Get git://codeaurora.org/tools/repo.git
- remote: Counting objects: 3425, done.
- remote: Total 3425 (delta 0), reused 0 (delta 0)
- Receiving objects: 100% (3425/3425), 753.71 KiB, done.
- Resolving deltas: 100% (2311/2311), done.
- From git://codeaurora.org/tools/repo
- * [new branch] aosp-new/maint -> origin/aosp-new/maint
- * [new branch] aosp-new/master -> origin/aosp-new/master
- * [new branch] aosp-new/stable -> origin/aosp-new/stable
- * [new branch] caf-stable -> origin/caf-stable
- * [new branch] master -> origin/master
- * [new branch] stable -> origin/stable
- * [new tag] v1.0 -> v1.0
- * [new tag] v1.0.1 -> v1.0.1
- ......
- Getting manifest ...
- from git:manifest
- remote: Counting objects: 18, done.
- remote: Compressing objects: 100% (16/16), done.
- remote: Total 18 (delta 4), reused 0 (delta 0)
- Unpacking objects: 100% (18/18), done.
- From git:manifest
- * [new branch] master -> origin/master
d. 接下来会要求初始化repo帐号信息,例子中与git保持一致,例如如下,中括号中的是git帐号信息,
在冒号后输入与其一致的信息即可:
- Your Name [willqian]: willqian
- Your Email [690004467@qq.com]: 690004467@qq.com
- Your identity is: willqian
- is this correct [y/n]? y
e. 此时,目录下会有一个隐藏文件夹.repo,完整版的repo位于路径
- .repo/repo/
6. repo同步项目
a. 同步
- cd test-project
- repo sync
我们进入到test仓库中查看,发现有一个问题,此时处于no branch的状态
- cd test
- git status
- # Not currently on any branch.
- nothing to commit (working directory clean)
b. 切到master分支上
- cd test-project
- repo start master --all
- cd test
- git status
- # On branch master
- nothing to commit (working directory clean)
至此,repo的完整安装以及项目同步的例子便以完成

PHP在現代編程中仍然是一個強大且廣泛使用的工具,尤其在web開發領域。 1)PHP易用且與數據庫集成無縫,是許多開發者的首選。 2)它支持動態內容生成和麵向對象編程,適合快速創建和維護網站。 3)PHP的性能可以通過緩存和優化數據庫查詢來提升,其廣泛的社區和豐富生態系統使其在當今技術棧中仍具重要地位。

在PHP中,弱引用是通過WeakReference類實現的,不會阻止垃圾回收器回收對象。弱引用適用於緩存系統和事件監聽器等場景,需注意其不能保證對象存活,且垃圾回收可能延遲。

\_\_invoke方法允許對象像函數一樣被調用。 1.定義\_\_invoke方法使對象可被調用。 2.使用$obj(...)語法時,PHP會執行\_\_invoke方法。 3.適用於日誌記錄和計算器等場景,提高代碼靈活性和可讀性。

Fibers在PHP8.1中引入,提升了並發處理能力。 1)Fibers是一種輕量級的並發模型,類似於協程。 2)它們允許開發者手動控制任務的執行流,適合處理I/O密集型任務。 3)使用Fibers可以編寫更高效、響應性更強的代碼。

PHP社區提供了豐富的資源和支持,幫助開發者成長。 1)資源包括官方文檔、教程、博客和開源項目如Laravel和Symfony。 2)支持可以通過StackOverflow、Reddit和Slack頻道獲得。 3)開發動態可以通過關注RFC了解。 4)融入社區可以通過積極參與、貢獻代碼和學習分享來實現。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP不是在消亡,而是在不斷適應和進化。 1)PHP從1994年起經歷多次版本迭代,適應新技術趨勢。 2)目前廣泛應用於電子商務、內容管理系統等領域。 3)PHP8引入JIT編譯器等功能,提升性能和現代化。 4)使用OPcache和遵循PSR-12標準可優化性能和代碼質量。

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。