Publishing your site
Теперь у вас должен быть настроенный и запущенный локально сайт. Как только вы настроили его по своему вкусу, настало время опубликовать его. Docusaurus создает статический HTML веб-сайт, готовый к запуску на на вашем любимом веб-сервере или через онлайн хостинг.
Создание статических HTML страниц
Чтобы создать статическую сборку своего веб-сайта, запустите следующую команду из каталога website
:
yarn run build # или `npm run build`
В результате будет создан каталог build
внутри каталога website
, содержащий файлы .html
для всех документов и других страниц, размещенных в pages
.
Хостинг статических HTML страниц
На этом этапе вы можете взять все файлы из каталога website/build
и скопировать их в каталог html
на вашем любимом веб-сервере.
Например, Apache и Nginx обслуживают содержимое каталога
/var/www/html
по-умолчанию. Впрочем, выбор веб-сервера или провайдера выходит за рамки Docusaurus.
При предоставлении доступа к своему сайту через ваш собственный веб-сервер, убедитесь, что сервер передает статические ресурсы с корректными HTTP заголовками. Файлы css должны быть переданы с заголовком
content-type
, имеющий значениеtext/css
. В случае Nginx это значит, что вам следует добавить строкуinclude /etc/nginx/mime.types;
в файлnginx.conf
. Просмотрите это обращение для получения дополнительной информации.
Хостинг на сервисах:
Использование ZEIT Now
Deploying your Docusaurus project to ZEIT Now will provide you with various benefits in the areas of performance and ease of use.
Most importantly, however, deploying a Docusaurus project only takes a couple seconds:
- Сначала установите интерфейс командной строки:
npm i -g now
- Запустите команду внутри корневого каталога вашего проекта:
now
That's all. Your docs will automatically be deployed.
Note that the directory structure Now supports is slightly different from the default directory structure of a Docusaurus project - The
docs
directory has to be within thewebsite
directory, ideally following the directory structure in this example. You will also have to specify acustomDocsPath
value insiteConfig.js
. Take a look at the the now-examples repository for a Docusaurus project.
Использование GitHub Pages
Docusaurus был спроектирован так, чтобы действительно хорошо работать с одним из самых популярных хостинговых решений для проектов с открытым исходным кодом: GitHub Pages.
Развертывание на GitHub Pages
- Docusaurus поддерживает развертывание сайта как Project Pages или User/Organization Pages, вашему репозиторию с кодом при этом даже не нужно быть публичным.
Даже если ваш репозиторий является приватным, все, что публикуется в ветке
gh-pages
станет публичным.
Note: When you deploy as user/organization page, the publish script will deploy these sites to the root of the master
branch of the username.github.io repo. В этом случае, обратите внимание, что вам понадобится инфраструктура Docusaurus, ваша документация и т. д. either in another branch of the username.github.io repo (e.g., maybe call it source
), or in another, separate repo (e.g. in the same as the documented source code).
- Вам потребуется изменить файл
website/siteConfig.js
и добавить необходимые параметры.
Наименование | Описание |
---|---|
organizationName | GitHub пользователь или организация, являющаяся владельцем репозитория. Если вы владелец проекта, то эта настройка - наименование вашей учетной записи на GitHub. In the case of Docusaurus, that would be the "facebook" GitHub organization. |
projectName | Наименование репозитория GitHub для вашего проекта. Например, исходный код Docusaurus размещен по адресу https://github.com/facebook/docusaurus, поэтому наш проект в этом случае будет называться «docusaurus». |
url | URL-aдрес вашего сайта. For projects hosted on GitHub pages, this will be "https://username.github.io" |
baseUrl | Базовый URL-адрес для вашего проекта. For projects hosted on GitHub pages, it follows the format "/projectName/". Для https://github.com/facebook/docusaurus, baseUrl равен /docusaurus/ . |
const siteConfig = {
...
url: 'https://__userName__.github.io', // Your website URL
baseUrl: '/testProject/',
projectName: 'testProject',
organizationName: 'userName'
...
}
In case you want to deploy as a user or organization site, specify the project name as <username>.github.io
or <orgname>.github.io
. E.g. If your GitHub username is "user42" then user42.github.io, or in the case of an organization name of "org123", it will be org123.github.io.
Note: Not setting the url
and baseUrl
of your project might result in incorrect file paths generated which can cause broken links to assets paths like stylesheets and images.
Хотя мы рекомендуем установить
projectName
иorganizationName
вsiteConfig.js
, вы также можете использовать переменные окруженияORGANIZATION_NAME
иPROJECT_NAME
.
- Теперь вы должны указать пользователя git как переменную окружения и запустить сценарий
publish-gh-pages
Наименование | Описание |
---|---|
GIT_USER | Имя пользователя для учётной записи GitHub, которая имеет доступ к данному репозиторию. Для ваших собственных репозиториев это будет обычное имя пользователя GitHub. Указанный GIT_USER должен иметь доступ к хранилищу, указанному в комбинации organizationName и projectName . |
Чтобы запустить скрипт непосредственно из командной строки, вы можете использовать следующую команду, заполняя значения параметров соответствующим образом.
Bash
GIT_USER=<GIT_USER> \
CURRENT_BRANCH=master \
USE_SSH=true \
yarn run publish-gh-pages # или `npm run publish-gh-pages`
Windows
cmd /C "set GIT_USER=<GIT_USER> && set CURRENT_BRANCH=master && set USE_SSH=true && yarn run publish-gh-pages"
Есть также два необязательных параметра, которые задаются в качестве переменных окружения:
Наименование | Описание |
---|---|
USE_SSH | Если задано значение true , то используется SSH вместо HTTPS для подключения к репозиторию GitHub. HTTPS используется по умолчанию, если эта переменная не задана. |
CURRENT_BRANCH | Ветвь, содержащая последние изменения для документов, которые будут развернуты. Обычно используется ветвь master , но это может быть любая ветвь (default или любая другая) за исключением gh-pages . Если значение не указано, будет использована текущая ветвь. |
Если вы столкнулись с проблемами, связанными с ключами SSH, посетите документацию по авторизации на GitHub.
You should now be able to load your website by visiting its GitHub Pages URL, which could be something along the lines of https://username.github.io/projectName, or a custom domain if you have set that up. For example, Docusaurus' own GitHub Pages URL is https://facebook.github.io/Docusaurus because it is served from the gh-pages
branch of the https://github.com/facebook/docusaurus GitHub repository. However, it can also be accessed via https://docusaurus.io/, via a generated CNAME
file which can be configured via the cname
siteConfig option.
Мы настоятельно рекомендуем ознакомиться с документацией GitHub Pages, чтобы узнать больше о том, как работает это решение для хостинга.
Вы можете запустить приведенную выше команду в любое время, когда вы обновляете документы и хотите развернуть изменения на своем сайте. Запуск сценария вручную может быть полезен для сайтов, на которых документация редко изменяется, и не следует забывать о том, что нужно вручную вносить изменения.
Однако вы можете автоматизировать процесс публикации с помощью непрерывной интеграции (CI).
Автоматизация развертываний с использованием непрерывной интеграции
Службы непрерывной интеграции (CI) обычно используются для выполнения рутинных задач всякий раз, когда новые коммиты регистрируются в системе контроля версий. Этими задачами могут быть любое сочетание запуска модульных и интеграционных тестов, автоматизации сборок, публикации пакетов в NPM и, конечно же, развертывания изменений на вашем веб-сайте. Все, что вам нужно сделать для автоматизации развертывания вашего сайта, - это запускать сценарий publish-gh-pages
всякий раз, когда ваши документы обновляются. В следующем разделе мы расскажем, как это сделать, используя Circle CI, популярного поставщика услуг непрерывной интеграции.
Using CircleCI 2.0
Если вы еще этого не сделали, вы можете установить CircleCI для своего проекта с открытым исходным кодом. После этого, чтобы включить автоматическое развертывание вашего сайта и документации через CircleCI, просто настройте Circle для запуска сценария publish-gh-pages
на этапе развертывания. Для настройки вы можете выполнить следующие шаги.
- Убедитесь, что учетная запись GitHub, которая будет установлена как
GIT_USER
, имеетправа на запись
в репозитории, содержащем документацию, проверивSettings | Collaborators & teams
в репозитории. - Войдите в GitHub как
GIT_USER
. - Перейдите в https://github.com/settings/tokens для
GIT_USER
и создайте новый токен личного доступа, предоставив ему полный контроль над частными репозиториями через доступ кrepository
. Храните этот токен в безопасном месте, не передавая его никому. Этот токен может использоваться для аутентификации действий на GitHub от вашего имени вместо вашего пароля на GitHub. - Open your CircleCI dashboard, and navigate to the Settings page for your repository, then select "Environment variables". URL выглядит как https://circleci.com/gh/ORG/REPO/edit#env-vars, где «ORG / REPO» должен быть заменен вашей собственной организацией/репозиторием на GitHub.
- Создайте новую переменную среды с именем
GITHUB_TOKEN
, используя в качестве значения вновь созданный токен доступа. - Создайте каталог
.circleci
иconfig.yml
в этом каталоге. - Скопируйте приведенный ниже текст в
.circleci/config.yml
.
# If you only want circle to run on direct commits to master, you can uncomment this out
# and uncomment the filters: *filter-only-master down below too
#
# aliases:
# - &filter-only-master
# branches:
# only:
# - master
version: 2
jobs:
deploy-website:
docker:
# specify the version you desire here
- image: circleci/node:8.11.1
steps:
- checkout
- run:
name: Deploying to GitHub Pages
command: |
git config --global user.email "<GITHUB_USERNAME>@users.noreply.github.com"
git config --global user.name "<YOUR_NAME>"
echo "machine github.com login <GITHUB_USERNAME> password $GITHUB_TOKEN" > ~/.netrc
cd website && yarn install && GIT_USER=<GIT_USER> yarn run publish-gh-pages
workflows:
version: 2
build_and_deploy:
jobs:
- deploy-website:
# filters: *filter-only-master
Обязательно замените все <....>
в последовательности command:
соответствующими значениями. Для <GIT_USER>
это должна быть учетная запись GitHub, которая имеет доступ к записи документации в ваш репозиторий GitHub. В большинстве случаев <GIT_USER>
и <GITHUB_USERNAME>
имеют одинаковые значения.
DO NOT place the actual value of $GITHUB_TOKEN
in circle.yml
. We already configured that as an environment variable back in Step 5.
Если вы желаете использовать SSH для подключения к своему репозиторию GitHub, вы можете указать
USE_SSH=true
. Таким образом, команда выше будет выглядеть следующим образом:cd website && npm install && GIT_USER=<GIT_USER> USE_SSH=true npm run publish-gh-pages
.
Unlike when you run the
publish-gh-pages
script manually when the script runs within the Circle environment, the value ofCURRENT_BRANCH
is already defined as an environment variable within CircleCI and will be picked up by the script automatically.
Теперь, когда новый коммит будет отправлен в master
, CircleCI запустит набор тестов и, если все они будут пройдены, развернет ваш сайт с помощью сценария publish-gh-pages
.
If you would rather use a deploy key instead of a personal access token, you can by starting with the CircleCI instructions for adding a read/write deploy key.
Советы и трюки
When initially deploying to a gh-pages
branch using CircleCI, you may notice that some jobs triggered by commits to the gh-pages
branch fail to run successfully due to a lack of tests (This can also result in chat/slack build failure notifications).
Вы легко можете обойти это следующим образом:
- Установите значение переменной окружения
CUSTOM_COMMIT_MESSAGE
для сценарияpublish-gh-pages
равной[skip ci]
. Например:
CUSTOM_COMMIT_MESSAGE="[skip ci]" \
yarn run publish-gh-pages # или `npm run publish-gh-pages`
- Кроме того, вы можете обойти эту проблему, создав базовый файл настроек CircleCI со следующим содержимым:
# CircleCI 2.0 Config File
# This config file will prevent tests from being run on the gh-pages branch.
version: 2
jobs:
build:
machine: true
branches:
ignore: gh-pages
steps:
- run: echo "Skipping tests on gh-pages branch"
Сохраните этот файл как config.yml
и разместите его в каталоге .circleci
внутри вашего каталога website/static
.
Использование Travis CI
- Перейдите по ссылке https://github.com/settings/tokens и создайте новый персональный токен доступа
- Используя свою учетную запись GitHub, добавьте приложение Travis CI к репозиторию, который вы желаете активировать.
- Откройте панель Travis CI. The URL looks like https://travis-ci.com/USERNAME/REPO, and navigate to the
More options
>Setting
>Environment Variables
section of your repository. - Создайте новую переменную окружения с именем
GH_TOKEN
и присвойте ей в качестве значения созданный токен, затем также создайте переменныеGH_EMAIL
(ваш email адрес) иGH_NAME
(имя вашей учетной записи GitHub). - Создайте файл
.travis.yml
в корне своего репозитория со следующим текстом.
# .travis.yml
language: node_js
node_js:
- '8'
branches:
only:
- master
cache:
yarn: true
script:
- git config --global user.name "${GH_NAME}"
- git config --global user.email "${GH_EMAIL}"
- echo "machine github.com login ${GH_NAME} password ${GH_TOKEN}" > ~/.netrc
- cd website && yarn install && GIT_USER="${GH_NAME}" yarn run publish-gh-pages
Теперь, когда новый коммит будет отправлен в master
, Travis CI запустит набор тестов и, если все они будут пройдены, развернет ваш сайт с помощью сценария publish-gh-pages
.
Хостинг на ZEIT Now
With ZEIT Now, you can deploy your site and connect it to GitHub or GitLab to automatically receive a new deployment every time you push a commit.
Хостинг на Netlify
Шаги по настройке вашего Docusaurus-сайта на Netlify.
Select New site from Git
Подключитесь к своему провайдеру Git.
Выберите ветку для развертывания. По-умолчанию это
master
Настройте шаги сборки:
- Для команды сборки введите:
cd website; npm install; npm run build;
- Для каталога публикации:
website/build/<projectName>
(используйтеprojectName
из своегоsiteConfig
)
- Для команды сборки введите:
Click Deploy site
Вы также можете настроить Netlify для построения сайта после каждого коммита в вашем репозитории, или только для коммитов в ветке master
.
Хостинг на Render
Render offers free static site hosting with fully managed SSL, custom domains, a global CDN and continuous auto deploys from your Git repo. Deploy your app in just a few minutes by following these steps.
Create a new Web Service on Render, and give Render's GitHub app permission to access your Docusaurus repo.
Выберите ветку для развертывания. The default is
master
.Enter the following values during creation.
Field Value Environment Static Site
Build Command cd website; yarn install; yarn build
Publish Directory website/build/<projectName>
projectName
is the value you defined in yoursiteConfig.js
.const siteConfig = { // ... projectName: 'your-project-name', // ...
That's it! Your app will be live on your Render URL as soon as the build finishes.
Публикация на GitHub Enterprise
Публикация на GitHub Enterprise должна работать по той же схеме, что и на github.com; вам только лишь нужно определить хост организации на GitHub Enterprise.
Наименование | Описание |
---|---|
GITHUB_HOST | Имя хоста для сервера GitHub enterprise. |
Добавьте в siteConfig.js
поле 'githubHost'
, которое будет содержать наименование хоста на GitHub Enterprise. Также вместо этого вы можете указать переменную окружения GITHUB_HOST
при вызове команды публикации.