ChatGPT解决这个技术问题 Extra ChatGPT

Where is the global git config data stored?

When using git config --global to set things up, to which file will it write?

Example:

git config --global core.editor "blah"

I can't find it at these places:

C:\Program Files\Git\etc\gitconfig

C:\myapp\.git\config

I have not set an ENV?

My Git version: 1.6.5.1.1367.gcd48 – on Windows 7

Are you using msysgit or something else?
git config --global --edit should tell you the exact location no matter what kind of setup you have--just look at what file comes up in your editor.
git config --global --list was also useful for when it doesn't exist as it gave the location of where git is expecting it to be.
@AJP: This is exactly my problem, but how to change where it wants to save/read it from??
git config --list --show-origin will tell you the location

S
Stevoisiak

Update 2016: with git 2.8 (March 2016), you can simply use:

git config --list --show-origin

And with Git 2.26 (Q1 2020), you can add a --show-scope option

git config --list --show-origin --show-scope

You will see which config is set where.
See "Where do the settings in my Git configuration come from?"

As Stevoisiak points out in the comments,

it will work with non-standard install locations. (i.e. Git Portable)

(like the latest PortableGit-2.14.2-64-bit.7z.exe, which can be uncompressed anywhere you want)

Original answer (2010)

From the docs:

--global For writing options: write to global ~/.gitconfig file rather than the repository .git/config.

Since you're using Git for Windows, it may not be clear what location this corresponds to. But if you look at etc/profile (in C:\Program Files\Git), you'll see:

HOME="$HOMEDRIVE$HOMEPATH"

Meaning:

C:\Users\MyLogin

(on Windows 7)

That means the file is in C:\Users\MyLogin\.gitconfig for Git in Windows 7.


I was being really dumb, I didnt add the "--global" flag to the edit command! "git config --global --edit" showed the file with all my config changes, "git config --edit" was the file I kept opening and thinking, where is that editor/compare/etc config item I just set! Many thanks.
Thanks. I've seen other places were it said it's at %USERPROFILE%. On my computer HOMEDRIVE and HOMEPATH are remapped to a network drive. Searches on my local drive were coming up with nothing. So this helped a lot.
Really useful, I was having the same issue - if you're on a domain with a mapped home drive it will try and create the git config there. This would make a good feature request - use %HOMEDRIVE% or %USERPROFILE%
Why is this called global, when it is only for one user? Wouldn't (for unix) /etc/gitconfig be "global" and ~/.gitconfig only be "local"..... and I guess .git/config "hyper-local" ----- Basically, I find the "global" term for this confusing, and I was wondering if there was a good reason for the nomenclature?
@PeterAjtai "global" because it is for all your repository. As opposed to "local" (only for one repo) or "system" (which is for all repo, for all users)
A
Alex Feinman

I was also looking for the global .gitconfig on my Windows machine and found this neat trick using git.

Do a: git config --global -e and then, if you are lucky, you will get a text editor loaded with your global .gitconfig file. Simply lookup the folder from there (or try a save as...), et voilà! :-)


Just what i was looking for! the -e command! Because editing a property at a time just isn't my gist.
Running this command will also create a C:\Users\<user_name>\.gitconfig if it is missing.
I'm running in a non-windowed mode and cannot find the location anywhere
M
Michael Freidgeim

On *nixes, it's in ~/.gitconfig. Is there a corresponding file in your home?

On Windows you can type in git bash

notepad ~/.gitconfig

This should be the same on windows.
If you wanna get to it easily, write an alias :) Here's mine: alias gitconfig='open -a Sublime\ Text.app ~/.gitconfig'. Use whatever text-editor you want.
h
hash

The paths for msysgit are:

Windows XP -C:\Documents and Settings\<user_name>\.gitconfig

Windows Vista+ C:\Users\<user_name>\.gitconfig


Probably better to describe this as %USERPROFILE% then the answer will work for all Windows versions, past, present, and future.
Except I think it's actually %HOMEDRIVE%%HOMEPATH% as in other answers, which is equal to %USERPROFILE% in many cases, but some of us have IT configurations pointing it to a mapped drive instead.
P
Philip Oakley

The global location is derived, on Windows MsysGit, using the HOMEDRIVE and HOMEPATH environment variables, unless you have defined a HOME environment variable. The is detailed in the 'profile' script.

In my corporate environment the HOMEDRIVE is H:, which is then mapped to a network URL \\share\$. The whole lot is then mapped to be "My Documents", which isn't where others would expect. There may have been some further problems with the drive to URL remapping. I don't even get to adjust the HOMEDRIVE or HOMEPATH variables anyway.

In my case I have defined a personal HOME environment variable and pointed it to D:\git\GitHOME and copied all those GIT files (which are without and extension) to the GitHOME directory for safe keeping.

The windows environment variables can be set via the Advanced tab in the My Computer properties dialog.


I was scrolling through the answers about to post on the HOMEDRIVE and HOMEPATH variables, since they just caught me out while using Bower. It seems a number of utilities on Windows read from <system>:\User\<username>\.gitconfig, while the Git tool itself saves to %HOMEPATH%\.gitconfig. I had to go one step further and copy the updated config file from my H:` (our network uses the same drive letter for that) to my local user folder, only then did Git use the rules correctly when called by Bower.
@ZaLiTHkA, In my corporate network the user's Home (H:) drive is them re-mapped back to the C:\User\ location as well, so I'd not noticed that. If you can identify which are the FOSS utilities that make the mistake then that would be useful info for helping getting round to reporting/fixing those tools. If they are internal corporate tools you are on your own ;-)
Unless it's more complicated than a simple setter line, I'm not seeing HOME defined in the etc\profile script. It does still seem to act as described, but I'm unclear where HOME is being set nowadays.
@ojchase My part of the answer of where --glob config is written related specifically to Windows. The core Linux git writes to places such as where the XDG thingy directs (i.e. I'm aware that linux writes to other places and has other conventions, and importantly it does have a root directory while Windows has 'Drives' ;-)
@PhilipOakley I was actually referring to Windows too; sorry I was unclear. Combining your answer and others, I was expecting some sort of HOME = $HOMEDRIVE$HOMEPATH (or similar) line in C:\Program Files\Git\etc\profile and that line doesn't seem to exist, but probably used to? I haven't been able to figure out exactly what is setting $HOME unless it's set by environment variable which I'd prefer not to do.
C
Cameron McKenzie

When is the global .gitconfig file created?

First off, git doesn't automatically create the global config file (.gitconfig) during its installation. The file is not created until it is written to for the first time. If you have never set a system variable, it will not be on your file system. I'm guessing that might be the source of the problem.

One way to ask Git to create it is to request an edit. Doing so will force the file's creation.

git config --global --edit

If you monitor the user's home folder when you issue this command, you will see the .gitconfig file magically appear.

Where is git configuration stored?

Here's a quick rundown of the the name and location of the configuration files associated with the three Git scopes, namely system, global and local:

System Git configuration: File named gitconfig located in -git-install-location-/ming<32>/etc

Global Git configuraiton: File named .gitconfig located in the user's home folder (C:\Users\git user)

Local Git configuration: File named config in the .git folder of the local repo

Of course, seeing is believing, so here's an image showing each file and each location. I pulled the image from an article I wrote on the topic.

Windows Git configuration file locations (TheServerSide.com)

https://i.stack.imgur.com/XqZJe.jpg


there is a forth place called the portable config : here they mention the 4 places ; Git for Windows supports four levels of configuration. At the lowest level is the machine specific configuration settings known as "portable" and lives a "%ProgramData%\Git\config"
Mind blown! I'm going to update the article with the new information. Cheers!
Y
Yue Lin Ho

If you are using TortoiseGit on a windows PC you can use:

Settings / Git / Config / Edit global .gitconfig

to open the global .gitignore file.

But if you use your Windows (7) PC in a domain your profile dir is may be a network share (mounted as a drive). In this case TortoiseGit (at least:1.6.5.0) is pointing you to the wrong dir (on c:...). See the closed TortoiseGit issue 922 for more information. Or using %HOMEDRIVE%%HOMEPATH% to open the dir that contains the .gitignore file.


P
Parzh from Ukraine

As @MatrixFrog pointed out in their comment, if the goal is to edit the config, you might want to run:

git config --global --edit

This command will open the config file (in this case, the --global one) in the editor of choice, and await for the file to be closed (just like during git rebase -i).


You can use this to figure out where the global .gitconfig is located - as long as your editor tells you what directory the file is located in. You can also use other switches (--system, --local, etc.) to find and edit other .gitconfig locations. P.S. -e is the same as --edit
that helped me to find where my compny hold the users configfile
B
Benny Neugebauer

I am using SmartGit with msysgit on Windows 8.1 and noticed that there can be three different locations for the gitconfig file:

%USERPROFILE%\.gitconfig
C:\Program Files (x86)\Git\etc\gitconfig
C:\Program Files (x86)\SmartGitHg\git\etc\gitconfig

But the one that is used is the one from %USERPROFILE%\.gitconfig.


s
samstav

It might be useful to note (for *nix platforms): some types of global git configuration/information are stored in /usr/share/git-core/, such as git autocompletion scripts and the following (default) hooks:

applypatch-msg

post-update

pre-commit

prepare-commit-msg

commit-msg

pre-applypatch

pre-rebase

update

Each of these can contain their own set of commands to execute, at the time described by their respective filenames.


Not useful for the OP question.
R
Rishabh B

Just completely agree with @cameron-mckenzie's answer here on this page, above about When is the global .gitconfig file created? (this clearly applies in case of every OS). Rest of his answer deals with Win7 systems.

In Win10 systems too, the .gitconfig global file would create for the very first time only when you tend to set user.name & user.email system variables via windows command-prompt.
As soon as it's set, the .gitconfig file would get created in %USERPROFILE% dir.

Below command works for Win & MacOS, both

So, let's suppose if .gitconfig file already exists. You can know its location via Command-prompt/Gitbash/Terminal by :

git config --global --list --show-origin

B
Bill Forster

I am running Windows 7 and using git as setup by following the instructions on GitHub (a year or two back). A rather common use-case I would have thought. None of the answers above helped me, and after much frustration I eventually found my 'real' gitconfig file in the following directory;

C:\Users\Bill\AppData\Local\GitHub\PortableGit_054f2e797ebafd44a30203088cd 3d58663c627ef\etc

Obviously substitute your user name and presumably the suffix after PortableGit_ is a unique GUID or similar.


This is only the case when using GitHub for Windows.
M
Machavity

I had also a problem with my global .gitconfig This is for the case someone also has this strange

git said:

fatal: unknown error occured while reading the configuration files

Now I fixed it. The problem was a second .gitconfig in this folder:

c:\Users\myUser.config\git\config

I don't know where it came from... But now everything works like a charme again.


B
Badr Elmers

I think it is important to post this quote:

Git for Windows supports four levels of configuration. At the lowest level is the machine specific configuration settings known as "portable" and lives a "%ProgramData%\Git\config". One priority level us the installation specific configuration settings known as "system", which live at "\mingw64\etc\gitconfig". Both of these configuration file, generally require elevated privileges to modify. Starting with the use specific values known as "global" configuration, which can be found at "%UserProfile%.gitconfig", we find the "user editable" configuration files. The highest priority configuration settings are in the "local" configuration, which can usually be found at ".git\config". It see the recommendation in the blog linked is to modify the "system" or "installation" specific configuration settings, which is fine but users should expect that other installations of Git would not absorb said settings. If you want machine wide settings, use the "portable" configuration file, otherwise choose the "global" or "local" configuration files. Hopefully, people find this information useful.

source


N
Northstrider

Uninstall Msysgit and install Cygwin + Git. Then global '.gitconfig' will be here: C:\cygwin(64)\home\[userName]\.gitconfig .

Now you don't have to worry about an environment variable which may be used by other programs. For example, my environment variable pointed me to a mapped drive in my work windows domain environment. I dont want my global .gitconfig sitting on my "home" mapped drive. I also don't know what might happen to other applications that might rely on that windows environment variable. Operations division might need that environment variable set to the mapped drive for a reason.

Also you don't have to worry about Mysysgit overwriting your 'profile' configuration settings if you specify a specific path to global '.gitconfig', using this method.

In general, save yourself and use cygwin bash shell in windows and be happier


r
rolandog

I had a similar issue; the problem was that the .gitconfig file was located in

C:\Users\MyLogin\.gitconfig\

(on Windows 7)

In other words, the file was located in C:\Users\MyLogin\.gitconfig\.gitconfig, instead of on C:\Users\MyLogin\.gitconfig (which is where Git was looking for the files).


x
xgqfrms

.gitconfig file location

macOS testing OK

global

# global config
$ cd ~/.gitconfig

# view global config
$ git config --global -l

local

# local config
$ cd .git/config

# view local config
$ git config -l

maybe a bonus for you:Vim or VSCode for edit git config


# open config with Vim

# global config
$ vim ~/.gitconfig

# local config
$ vim .git/config


# open config with VSCode

# global config
$ code ~/.gitconfig

# local config
$ code .git/config


h
hx_hxl

git help config

Files section have a detailed description.

https://i.stack.imgur.com/DNCf5.png


A
AS Mackay

I had installed my Git in: C:\Users\_myuserfolder_\AppData\Local\Programs\Git