Разверните проект с помощью Git push

Я бы сделал следующее:

String title_part = "title part1.txt";
int i;
for(i=title_part.length()-1 ; i>=0 && title_part.charAt(i)!='.' ; i--);
title_part = title_part.substring(0,i);

Начиная с конца до '.' затем вызовите подстроку.

Изменить: не может быть гольф, но он эффективен:)

409
задан Nick Volynkin 7 June 2015 в 00:17
поделиться

6 ответов

Я нашел этот сценарий на этот сайт , и это, кажется, работает вполне хорошо.

  1. Копия по Вашему .git каталогу к Вашему веб-серверу
  2. На Вашей локальной копии, измените свой .git/config файл и добавьте свой веб-сервер как удаленное:

    [remote "production"]
        url = username@webserver:/path/to/htdocs/.git
    
  3. На сервере, замена .git/hooks/post-update этот файл (в ответе ниже)

  4. Добавляют доступ на выполнение к файлу (снова, на сервере):

    chmod +x .git/hooks/post-update
    
  5. Теперь, просто локально продвиньте к своему веб-серверу, и он должен автоматически обновить рабочую копию:

    git push production
    
287
ответ дан Community 7 June 2015 в 00:17
поделиться

Путем я делаю это, у меня есть пустой репозиторий Мерзавца на моем сервере развертывания, где я продвигаю изменения. Тогда я вхожу в систему сервера развертывания, изменяюсь на фактический каталог документов веб-сервера и делаю получение по запросу мерзавца. Я не использую рычагов, чтобы попытаться сделать это автоматически, которое походит на большую проблему, чем это стоит.

9
ответ дан Greg Hewgill 7 June 2015 в 00:17
поделиться

Кажется, что у Вас должно быть две копии на Вашем сервере. Пустая копия, от которой можно продвинуть/вытянуть, который Ваш продвинул бы изменения, когда Вы сделаны, и затем Вы клонировали бы это в Вас веб-каталог и настроили бы cronjob для обновления получения по запросу мерзавца из веб-каталога каждый день или около этого.

1
ответ дан Flame 7 June 2015 в 00:17
поделиться

Вы могли очевидно настроить рычаг мерзавца, что, когда говорят, фиксация сделана сказать "стабильное" ответвление, это вытянет изменения и применит их к сайту PHP. Большая оборотная сторона - Вы, не будет иметь большого контроля, если что-то пойдет не так, как надо, и это добавит время к Вашему тестированию - но можно понять то, сколько работы будет включено, когда Вы объединитесь, говорит Ваше магистральное ответвление в стабильное ответвление для знания, с каким количеством конфликтов Вы можете сталкиваться. Будет важно следить за любыми файлами, которые являются конкретным сайтом (например, конфигурационные файлы), если Вы только не намереваетесь только выполнить один сайт.

, Кроме того, Вы изучили продвижение изменения в сайте вместо этого?

Для получения информации о рычагах мерзавца посмотрите документация githooks .

1
ответ дан Chealion 7 June 2015 в 00:17
поделиться

По сути, все, что вам нужно сделать, это следующее:

server = $1
branch = $2
git push $server $branch
ssh <username>@$server "cd /path/to/www; git pull"

У меня эти строки находятся в моем приложении в виде исполняемого файла под названием deploy.

поэтому, когда я хочу выполнить развертывание, я набираю ./deploy myserver mybranch.

12
ответ дан 22 November 2019 в 23:31
поделиться

Используя файл post-update ниже:

  1. Скопируйте каталог .git на свой веб-сервер
  2. В локальной копии измените файл .git / config и добавьте свой веб-сервер в качестве удаленного:

      [удаленное «производство»]
    url = (скрыто)
    
  3. На сервере замените .git / hooks / post-update файлом ниже

  4. Добавьте доступ на выполнение к файлу (опять же, на сервере):

     chmod + x .git / hooks / post-update
    
  5. Теперь просто нажмите локально на свой веб-сервер, и он автоматически обновит рабочую копию:

     git push production
    
#!/bin/sh
#
# This hook does two things:
#
#  1. update the "info" files that allow the list of references to be
#     queries over dumb transports such as http
#
#  2. if this repository looks like it is a non-bare repository, and
#     the checked-out branch is pushed to, then update the working copy.
#     This makes "push" function somewhat similarly to darcs and bzr.
#
# To enable this hook, make this file executable by "chmod +x post-update". 
git-update-server-info 
is_bare=$(git-config --get --bool core.bare) 
if [ -z "$is_bare" ]
then
      # for compatibility's sake, guess
      git_dir_full=$(cd $GIT_DIR; pwd)
      case $git_dir_full in */.git) is_bare=false;; *) is_bare=true;; esac
fi 
update_wc() {
      ref=$1
      echo "Push to checked out branch $ref" >&2
      if [ ! -f $GIT_DIR/logs/HEAD ]
      then
             echo "E:push to non-bare repository requires a HEAD reflog" >&2
             exit 1
      fi
      if (cd $GIT_WORK_TREE; git-diff-files -q --exit-code >/dev/null)
      then
             wc_dirty=0
      else
             echo "W:unstaged changes found in working copy" >&2
             wc_dirty=1
             desc="working copy"
      fi
      if git diff-index --cached HEAD@{1} >/dev/null
      then
             index_dirty=0
      else
             echo "W:uncommitted, staged changes found" >&2
             index_dirty=1
             if [ -n "$desc" ]
             then
                   desc="$desc and index"
             else
                   desc="index"
             fi
      fi
      if [ "$wc_dirty" -ne 0 -o "$index_dirty" -ne 0 ]
      then
             new=$(git rev-parse HEAD)
             echo "W:stashing dirty $desc - see git-stash(1)" >&2
             ( trap 'echo trapped $$; git symbolic-ref HEAD "'"$ref"'"' 2 3 13 15 ERR EXIT
             git-update-ref --no-deref HEAD HEAD@{1}
             cd $GIT_WORK_TREE
             git stash save "dirty $desc before update to $new";
             git-symbolic-ref HEAD "$ref"
             )
      fi 
      # eye candy - show the WC updates :)
      echo "Updating working copy" >&2
      (cd $GIT_WORK_TREE
      git-diff-index -R --name-status HEAD >&2
      git-reset --hard HEAD)
} 
if [ "$is_bare" = "false" ]
then
      active_branch=`git-symbolic-ref HEAD`
      export GIT_DIR=$(cd $GIT_DIR; pwd)
      GIT_WORK_TREE=${GIT_WORK_TREE-..}
      for ref
      do
             if [ "$ref" = "$active_branch" ]
             then
                   update_wc $ref
             fi
      done
fi
78
ответ дан 22 November 2019 в 23:31
поделиться
Другие вопросы по тегам:

Похожие вопросы: