Skip to content

Synchronization of two remote Git repositories. Two remotes as one. Auto conflict solving by Convention over Git. Client-Vendor conception.

Notifications You must be signed in to change notification settings

particleman314/git-sync

 
 

Repository files navigation

git-sync

git-sync is an automated synchronization of two remote Git repositories with auto conflict solving.

Scenarios of usage

  • Auto synchronization of remote Git-repositories.
  • Sharing of a repository with limited internet access with your partners.
  • Keeping of repositories neat and sane between customers and clients.

Playground

If you will run git-sync.sh without parameters, then a test environment will be created.
You will get two remote and two local interconnected repositories on your machine.
Make changes there, run git-sync.sh, see behavour and results.

How it works

Imagine, there are two remote repositories. Each repository is a separate side.
You agreed that

  • the first repository owns a prefix foo-
  • the second repository owns a prefix bar/
  • branch names after prefixes are arbitrary.

Only branches with such the prefixes will be synchronized and visible on both sides.

Git conflicts solving
Conflicts may occur only if your do merges or commits to another side branches.
The prefix owner will win in case of any conflicts.
Commits of a loser will be rejected, but he just has to repeat merge or commits again (from his local repository) after a Git update (fetch, pull, merge, etc).

Git-tags I've excluded Git-tags from synchronization. Nothing wrong with tags but there are some nervous subtleties with them.

FAQ

Why is everything done so? - This is a proven and working solution. But it is also modest and supported by a single person, me.
Why do not synchronize everything at once? - You will spend significant resources to make to professionally.
Is it possible to synchronize all branches and tags? - Yes. I had other solutions and ideas. No one is interested.
Why do not sync Git-tags? - This is disabled also because some popular Git-servers block deletion of tags.

I warned you

Most of the following sections describe technical details.
if you are technically savvy, I expect you will complete everything from one day to one week. Depends on your situation and needs.
The only thing I want to say, this is really working.
I am waiting for your notes and wish you luck.

Need help?

Ask me. I'll answer on you questions ASAP.
See my contacts at it3xl.com.

If you are not ready to spend your time, then I can do everything for you.
I am offering a complete package that includes

  • Working solution
  • One year support
  • Automated backups of your repositories
  • Notifications about conflict solving or branch deletion
  • reasonable customizations for you cases

Features

  • Prevention of an occasional deletion of an entire repository.
  • Deletion and creation of branches from one side repository to another.
  • Auto conflict solving by Convention over Git (non-fast-forward branch conflicts).
  • Recreation of the synchronization from any position and from scratch.
  • Failover & auto recovery of synchronization is supported. Especially for network troubles.
  • Solution is applied per-repository (not per-server)
  • Synchronization of the Git-tags was removed because GitLab loves to block tag's deletion.
  • Single non-bare Git repository is used for the synchronization.
  • You can attach your automations to notify about conflict solving or a branch deletion.

Provinding credentials for Git

I use my bash Git Credential Helper git-cred
It passes to Git credentials from enviroment variables created by Continues Intergration tools like Jenkins.
It is inegrated now with git-sync.

What to expect next

Victim Branches

I've temporary postponed this feature. Everybody can live without it. Although it is annoying.

We have some branches that reflect all our stands (dev, test, UAT, pre-prod).
Any commit three runs complete CI/CD processes.
It is useful to allow any team sides to put this branches at any position, on any commit.
I think it is time to add such branches into git-sync.

E.g.
victim/test-stand
victim-test-stand

The Glossary

Here is my glossary related to the topic.

How to Use

You need to describe the prefixes and simple details of your real remote repositories in a simple config-file.
Create the same file as your_repo_some_name.sh.

Run the git-sync and pass a path to your config file as a parameter.

bash git-sync.sh "relative_or_absolute_path/project_settings.sh"

Run git-sync so periodically, better once in a minute.

That's all. You may work and forget about git-sync.
In the case of any synchronization interruption git-sync will do everything right.

Prepare Environment

Use any *nix or Window machine.

Install Git

For *nix users - update you bash and awk to any modern version

Tune any automation to invocate git-sync periodically - crons, schedulers, Jenkins, GitLab-CI, etc.

About

Synchronization of two remote Git repositories. Two remotes as one. Auto conflict solving by Convention over Git. Client-Vendor conception.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 62.0%
  • Awk 38.0%