From 0273b2905737e41babb0bfba7f4c33100bd40d68 Mon Sep 17 00:00:00 2001 From: James Moger Date: Tue, 27 Mar 2012 16:53:04 -0400 Subject: Documentation --- docs/01_setup.mkd | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'docs/01_setup.mkd') diff --git a/docs/01_setup.mkd b/docs/01_setup.mkd index c5d78def..75b51419 100644 --- a/docs/01_setup.mkd +++ b/docs/01_setup.mkd @@ -393,17 +393,23 @@ Like anything else, this design has pros and cons. 2. you specify exactly what branches are indexed; experimental/dead/personal branches can be ignored #### Cons -1. you have to opt-in a repository _after_ it is created and has some commits -2. you specify exactly what branches are indexed +1. you specify exactly what branches are indexed -#### Why does Gitblit check every 2 mins for repository/branch changes? +#### I have 300 repositories and you want me to specify indexed branches on each one?? -Gitblit has to balance its design as a complete, integrated Git server and its utility as a repository viewer in an existing Git setup. +Yeah, I agree that is inconvenient. -Gitblit could build indexes immediately on *edit repository* or on *receiving pushes*, but that design would not work if someone is pushing via ssh://, git://, or file:// (i.e. not pushing to Gitblit http(s)://). For this reason Gitblit has a polling mechanism to check for ref changes every 2 mins. This design works well for all use cases, aside from adding a little lag in updating the index. +If you are using Gitblit GO there is a utility script `add-indexed-branch.cmd` which allows you to specify an indexed branch for many repositories in one step. + +If you are using Gitblit WAR then, at present, you are out of luck unless you write your own script to traverse your repositories and use native Git to manipulate each repository config. + + git config --add gitblit.indexBranch "default" + git config --add gitblit.indexBranch "refs/heads/master" #### Indexing Branches -You may specify which branches should be indexed per-repository in the *Edit Repository* page. New/empty repositories can not pre-specify indexed branches; you can only specify indexed branches for a repository with commits. Indexes are built and incrementally updated on a 2 minute cycle so you may have to wait a few minutes before your index is built or before your latest pushes get indexed. +You may specify which branches should be indexed per-repository in the *Edit Repository* page. New/empty repositories may only specify the *default* branch which will resolve to whatever commit HEAD points to or the most recently updated branch if HEAD is unresolvable. + +Indexes are built and incrementally updated on a 2 minute cycle so you may have to wait a few minutes before your index is built or before your latest pushes get indexed. **NOTE:** After specifying branches, only the content from those branches can be searched via Gitblit. Gitblit will automatically redirect any queries entered on a repository's search box to the Lucene search page. Repositories that do not specify any indexed branches will use the traditional commit-traversal search. @@ -412,6 +418,12 @@ After specifying branches, only the content from those branches can be searched The initial indexing of an existing repository can potentially exhaust the memory allocated to your Java instance and may throw OutOfMemory exceptions. Be sure to provide your Gitblit server adequate heap space to index your repositories. The heap is set using the *-Xmx* JVM parameter in your Gitblit launch command (e.g. -Xmx1024M). +#### Why does Gitblit check every 2 mins for repository/branch changes? + +Gitblit has to balance its design as a complete, integrated Git server and its utility as a repository viewer in an existing Git setup. + +Gitblit could build indexes immediately on *edit repository* or on *receiving pushes*, but that design would not work if someone is pushing via ssh://, git://, or file:// (i.e. not pushing to Gitblit http(s)://). For this reason Gitblit has a polling mechanism to check for ref changes every 2 mins. This design works well for all use cases, aside from adding a little lag in updating the index. + ## Client Setup and Configuration ### Https with Self-Signed Certificates You must tell Git/JGit not to verify the self-signed certificate in order to perform any remote Git operations. -- cgit v1.2.3