Programing

git 저장소에 여러 프로젝트를 배치하는 가장 좋은 방법은 무엇입니까?

crosscheck 2020. 6. 6. 08:18
반응형

git 저장소에 여러 프로젝트를 배치하는 가장 좋은 방법은 무엇입니까? [닫은]


어떤 이유로 든 사용할 저장소하나 뿐입니다 .
그러나 프로젝트 앱 프로젝트를 포함한 여러 프로젝트가 있습니다.javaphp scriptsAndroid

이제 내 문제는 다른 IDE를 사용 하는 저장소 내의 다른 하위 폴더에 파일 을 넣어야한다는
것입니다. 각 IDE에는 자체 작업 공간이있을 수 있습니다.

누가 문제를 해결하기위한 모범 사례를 말해 줄 수 있습니까?


대부분의 사람들이 여러 저장소를 사용하도록 지시하지만 다른 솔루션이 있다고 말할 가치가 있다고 생각합니다.

해결책 1

단일 저장소에는 고아 분기 라는 여러 개의 독립적 인 분기 가 포함될 수 있습니다 . 고아 지점은 서로 완전히 분리되어 있습니다. 그들은 역사를 공유하지 않습니다.

git checkout --orphan BRANCHNAME

현재 브랜치와 관련이없는 새 브랜치를 만듭니다. 각 프로젝트는 자체 분리 된 분기에 있어야합니다.

어떤 이유로 든 git은 고아 체크 아웃 후 약간의 정리가 필요합니다.

rm .git/index
rm -r *

삭제하기 전에 모든 것이 커밋되었는지 확인하십시오

고아 지점이 깨끗해지면 정상적으로 사용할 수 있습니다.

해결책 2

번거로운 고아 지점을 피하십시오. 두 개의 독립적 인 리포지토리를 생성하고 동일한 원격으로 푸시하십시오. 각 리포지토리마다 다른 브랜치 이름을 사용하십시오.

# repo 1
git push origin master:master-1

# repo 2
git push origin master:master-2

해결책 3

여러 프로젝트에 단일 디렉토리를 사용하기위한 것입니다. 필자는이 기법을 밀접하게 관련된 일부 프로젝트에 자주 사용하는데, 프로젝트간에 변경 사항을 자주 가져와야합니다. 고아 브랜치 아이디어와 비슷하지만 브랜치가 고아 일 필요는 없습니다. 동일한 빈 디렉토리 상태에서 모든 프로젝트를 시작하십시오.

하나의 커밋 된 빈 디렉토리에서 모든 프로젝트를 시작하십시오.

이 솔루션에서 놀라운 것을 기대하지 마십시오. 내가 알다시피, 당신은 항상 추적되지 않은 파일로 성 가실 것입니다. Git은 실제로 무엇을 해야할지 알지 못하므로 컴파일러가 생성하고 .gitignore 파일에 의해 무시되는 중간 파일이있는 경우 빠르게 스왑하려고하면 시간이 약간 걸릴 수 있습니다 예를 들어 소프트웨어 프로젝트와 PH.D 논문 프로젝트 사이.

그러나 여기에 계획이 있습니다. 빈 저장소를 커밋하여 git 프로젝트를 시작한 다음 시작한 다음 동일한 빈 디렉토리 상태에서 모든 프로젝트를 시작하십시오. 그렇게하면 두 개의 많은 파일이 상당히 독립적임을 확신 할 수 있습니다. 또한 지사에 적절한 이름을 지정하고 게으르게 "마스터"를 사용하지 마십시오. 프로젝트를 분리해야하므로 적절한 이름을 지정하십시오.

Git 커밋 (따라서 태그와 브랜치)은 기본적으로 디렉토리와 하위 디렉토리의 상태를 저장하며 Git은 동일한 프로젝트 또는 다른 프로젝트의 일부인지 전혀 알지 못 하므로 실제로 동일한 저장소에 다른 프로젝트를 저장하는 git에는 아무런 문제가 없습니다. 문제는 다른 프로젝트를 사용하거나 나중에 프로젝트를 분리 할 때 한 프로젝트에서 추적되지 않은 파일을 지우는 것입니다.

빈 저장소 만들기

cd some_empty_directory
git init
touch .gitignore
git add .gitignore
git commit -m empty
git tag EMPTY

빈 프로젝트부터 시작하십시오.

하나의 프로젝트로 작업하십시오.

git branch software EMPTY
git checkout software
echo "array board[8,8] of piece" > chess.prog

git add chess.prog 
git commit -m "chess program"

다른 프로젝트를 시작하십시오

니가 좋을 때 아무 때 나.

git branch thesis EMPTY
git checkout thesis
echo "the meaning of meaning" > philosophy_doctorate.txt
git add philosophy_doctorate.txt 
git commit -m "Ph.D"

앞뒤로 전환

원할 때마다 프로젝트 간을 앞뒤로 이동하십시오. 이 예제는 체스 소프트웨어 프로젝트로 돌아갑니다.

git checkout software
echo "while not end_of_game do make_move()" >> chess.prog
git add chess.prog 
git commit -m "improved chess program"

추적되지 않은 파일은 성가시다

그러나 프로젝트 / 브랜치간에 스왑 할 때 추적되지 않은 파일에 짜증이 날 것입니다.

touch untracked_software_file.prog
git checkout thesis 
ls
    philosophy_doctorate.txt  untracked_software_file.prog

극복 할 수없는 문제는 아닙니다

정의에 따르면, git은 추적되지 않은 파일로 무엇을해야하는지 잘 모르며 파일을 처리하는 것은 사용자의 책임입니다. 다음과 같이 추적되지 않은 파일이 한 지점에서 다른 지점으로 이동하는 것을 막을 수 있습니다.

git checkout EMPTY 
ls
    untracked_software_file.prog
rm -r *
    (directory is now really empty, apart from the repository stuff!)
git checkout thesis
ls
    philosophy_doctorate.txt

새 프로젝트를 확인하기 전에 디렉토리가 비어 있는지 확인하여 다른 프로젝트에서 추적되지 않은 파일이 걸려 있지 않은지 확인했습니다.

개선

$ GIT_AUTHOR_DATE='2001-01-01:T01:01:01' GIT_COMMITTER_DATE='2001-01-01T01:01:01' git commit -m empty

If the same dates are specified whenever committing an empty repository, then independently created empty repository commits can have the same SHA1 code. This allows two repositories to be created independently and then merged together into a single tree with a common root in one repository later.

Example

# Create thesis repository. 
# Merge existing chess repository branch into it

mkdir single_repo_for_thesis_and_chess
cd single_repo_for_thesis_and_chess
git init
touch .gitignore
git add .gitignore
GIT_AUTHOR_DATE='2001-01-01:T01:01:01' GIT_COMMITTER_DATE='2001-01-01:T01:01:01' git commit -m empty
git tag EMPTY
echo "the meaning of meaning" > thesis.txt
git add thesis.txt
git commit -m "Wrote my PH.D"
git branch -m master thesis

# It's as simple as this ...
git remote add chess ../chessrepository/.git
git fetch chess chess:chess

Result

Diagram of merged repositories

Use subdirectories per project?

It may also help if you keep your projects in subdirectories where possible, e.g. instead of having files

chess.prog
philosophy_doctorate.txt 

have

chess/chess.prog
thesis/philosophy_doctorate.txt 

In this case your untracked software file will be chess/untracked_software_file.prog. When working in the thesis directory you should not be disturbed by untracked chess program files, and you may find occasions when you can work happily without deleting untracked files from other projects.

Also, if you want to remove untracked files from other projects, it will be quicker (and less prone to error) to dump an unwanted directory than to remove unwanted files by selecting each of them.

Branch names can include '/' characters

So you might want to name your branches something like

project1/master
project1/featureABC
project2/master
project2/featureXYZ

I would use git submodules.

have a look here Git repository in a Git repository

As per February2019, I would suggest Monorepos

참고URL : https://stackoverflow.com/questions/14679614/whats-the-best-practice-for-putting-multiple-projects-in-a-git-repository

반응형