mirror of
https://github.com/AlexBocken/mykb.git
synced 2024-11-24 04:02:18 +01:00
Added GIT
This commit is contained in:
parent
0d66ba31be
commit
c940054117
2
TODO.md
2
TODO.md
@ -1,4 +1,4 @@
|
|||||||
# General
|
# General
|
||||||
- [ ] create a script as a wrapper to these docs similar to tldr/kb
|
- [ ] create a script as a wrapper to these docs similar to tldr/kb
|
||||||
- [ ] create wrapper script for md to html export
|
- [X] create wrapper script for md to html export
|
||||||
- Maybe usage of bundestag wrapper scrips?
|
- Maybe usage of bundestag wrapper scrips?
|
||||||
|
86
docs/GIT.md
Normal file
86
docs/GIT.md
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
# General
|
||||||
|
|
||||||
|
GIT is a version control software, that allows you to save the progress of software/text/whatever development.
|
||||||
|
It is probably best know from GitHub, but we will show how to set up your own GIT instance and how to use it.
|
||||||
|
|
||||||
|
## Installing GIT
|
||||||
|
|
||||||
|
### What you need
|
||||||
|
|
||||||
|
1. A working server, being it self-hosted at home or a remote instance, called REMOTE in the following
|
||||||
|
2. A local machine that you develop whatever on, called LOCAL in the following
|
||||||
|
|
||||||
|
### Installing GIT
|
||||||
|
|
||||||
|
On the LOCAL machine, use your favorite package manager, for example
|
||||||
|
|
||||||
|
```sh
|
||||||
|
pacman -S git
|
||||||
|
```
|
||||||
|
|
||||||
|
The same holds for the REMOTE machine, but here I would advice, to use some LTS distro, so probably
|
||||||
|
|
||||||
|
```sh
|
||||||
|
sudo apt install git
|
||||||
|
```
|
||||||
|
|
||||||
|
### Setting up the Server
|
||||||
|
|
||||||
|
First we have to add the git-user on the REMOTE, give him a password and enable ssh logins.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
sudo adduser git
|
||||||
|
su git
|
||||||
|
passwd
|
||||||
|
cd
|
||||||
|
mkdir .ssh & chmod 700 .ssh
|
||||||
|
touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys
|
||||||
|
```
|
||||||
|
Now add the ssh public keys of your LOCAL machine to the `authorized_keys` file on the REMOTE.
|
||||||
|
For this on the LOCAL machine generate a key-pair using `ssh-keygen -t rsa` if you don't have one yet.
|
||||||
|
Then copy the content of `LOCAL/.ssh/id_rsa.pub` to the `REMOTE/.ssh/authorized_keys` file.
|
||||||
|
|
||||||
|
## New Repository
|
||||||
|
|
||||||
|
To initialize a repository on the REMOTE server we have to create a new folder and tell git to track this folder.
|
||||||
|
This has to be done once for every new repository.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
cd
|
||||||
|
mkdir NewRepo.git
|
||||||
|
cd NewRepo.git
|
||||||
|
git init --bare
|
||||||
|
```
|
||||||
|
|
||||||
|
On the LOCAL machine we then have to create a folder and tell git to sync this with the server.
|
||||||
|
We will assume that `REMOTE` is either the IP or the domain-name of the REMOTE instance.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
cd project
|
||||||
|
git init
|
||||||
|
git add .
|
||||||
|
git commit -m 'Initial commit'
|
||||||
|
git remote add origin git@REMOTE:/home/git/NewRepo.git
|
||||||
|
git push origin master
|
||||||
|
```
|
||||||
|
|
||||||
|
## Using Git
|
||||||
|
|
||||||
|
To now sync this folder to other devices use
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git clone git@gitserver:/home/git/NewRepo.git
|
||||||
|
cd project
|
||||||
|
```
|
||||||
|
|
||||||
|
To update the repository go to the folder, add the necessary files using `git add <FILES>` and then commit them using `git commit -m '<MESSAGE>`. These steps can be done as one using
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git commit -am 'Fix for README file'
|
||||||
|
```
|
||||||
|
|
||||||
|
Now push it to the server using `git push origin master`.
|
||||||
|
|
||||||
|
### Further Info
|
||||||
|
|
||||||
|
- [Git Website](https://git-scm.com/book/en/v2/Git-on-the-Server-Setting-Up-the-Server)
|
@ -1,6 +1,4 @@
|
|||||||
# General
|
# General
|
||||||
|
|
||||||
SSH is a helper utensil to connnect to remote servers.
|
|
||||||
The basic syntax is
|
The basic syntax is
|
||||||
```
|
```
|
||||||
ssh user@domain
|
ssh user@domain
|
||||||
@ -19,8 +17,7 @@ Change the permisions of this folder using `chmod 700 ~/.ssh`.
|
|||||||
The next step is to make the `authorized_keys` file using
|
The next step is to make the `authorized_keys` file using
|
||||||
```
|
```
|
||||||
touch ~/authorized_keys
|
touch ~/authorized_keys
|
||||||
chmod 600 ~/.ssh/authorized_keys
|
chmod 600 ~/.ssh/authorized_keys ```
|
||||||
```
|
|
||||||
Now open the `authorized_keys` and copy-paste the public key contents in to it.
|
Now open the `authorized_keys` and copy-paste the public key contents in to it.
|
||||||
|
|
||||||
One can also use `ssh-copy-id user@domain` after generating the key-pair.
|
One can also use `ssh-copy-id user@domain` after generating the key-pair.
|
||||||
|
1
index.md
1
index.md
@ -10,6 +10,7 @@ Happy to accept pull requests for new topics!
|
|||||||
A wiki script for vim
|
A wiki script for vim
|
||||||
- [weechat](docs/weechat.md) A TUI client for matrix
|
- [weechat](docs/weechat.md) A TUI client for matrix
|
||||||
- [ssh](docs/ssh.md) ssh configuration
|
- [ssh](docs/ssh.md) ssh configuration
|
||||||
|
- [GIT](GIT) A version control software
|
||||||
|
|
||||||
# Admin
|
# Admin
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user