Configuring Secondary Node
In addition to the main TeamCity server, you can start a secondary server (node) sharing the Data Directory and database with the main one. Read more in Multinode Setup.
This page describes how to configure a secondary node.
On this page:
- Installing Secondary Node
- Startup & Shutdown
- Assigning Responsibilities
- Upgrade & Downgrade
- Authentication & License
- Global Settings
- Project Import
- Using Plugins
- Backup & Restore
Installing Secondary Node
To install a secondary node, follow these steps:
On the secondary node machine, install the TeamCity software as usual: download the distribution package and follow the installation wizard.
Provide the path to the shared Data Directory via the
Add additional arguments to the
<nodeID>is the ID of the node that will be displayed on the Administration | Nodes Configuration page.
<path_to_node_data_directory>is the path to the node Data Directory (see Node-Specific Data Directory).
<node url>is the secondary node root URL. Make sure this URL is accessible from the main server and agents.
Secondary Node Memory Settings
The secondary node requires the same memory settings as the main node. If you have already configured the
TEAMCITY_SERVER_MEM_OPTS environment variable for the main node, make sure to use the same variable for the secondary node. If your main node uses a 64-bit JVM, the secondary node must use a 64-bit JVM as well.
Startup & Shutdown
A secondary node can be started/stopped using regular TeamCity scripts (
teamcity-server.sh) or Windows services.
Before starting more than one secondary node, make sure the database is configured to accept enough parallel connections to handle requests from all nodes. By default, each node requires 50 connections to the database.
The secondary node server uses the same approach to logging as the main server. You can check the state of the startup in the
<TeamCity_installation_directory>/logs/teamcity-server.log file. Open
<secondary_node_URL> in your browser to see the regular TeamCity startup screens.
A secondary node, as well as the main server, can be stopped or restarted while builds are running. If agents cannot connect to a secondary node for some time, they will reroute their data to the main server. If the main server is unavailable either, agents will keep their data and resend it once the servers are available again.
By default, a newly started secondary node provides a read-only user interface and does not perform any background activity. You can assign the following additional responsibilities to each secondary node in Administration | Server Administration | Nodes Configuration:
Processing data produced by builds
VCS repositories polling
A node assigned with any responsibility will allow users to perform the most common actions on builds (read more in Multinode Setup).
You can enable and disable responsibilities for nodes at any moment.
Processing Data Produced by Builds on Secondary Node
It is possible to use one or more secondary nodes to process traffic from the TeamCity agents. This allows moving the related load to a separate machine from the main TeamCity server which will improve the TeamCity performance when handling hundreds of concurrent and actively logging builds.
In general, you do not need a separate node for running builds unless you have more than 400 agents connected to a single server. Using a secondary node allows you to significantly increase the number of agents which the setup can handle.
Once you assign the Processing data produced by builds responsibility to a node, all newly started builds will be routed to this node. The existing running builds will continue being executed on the main server. When you disable the responsibility, only the newly started builds will be switched to the main server. The builds that were already running on the secondary node will continue running there.
VCS Repositories Polling on Secondary Node
Usually, the main TeamCity server polls the VCS repositories for changes to detect new commits. You can delegate VCS polling to the secondary node thus improving the performance of the main server. Only one secondary node can be assigned to this responsibility.
Once you assign the VCS repositories polling responsibility to a node, it may take some time for the main server to finish the polling activities in progress, and then the secondary node will pick up this task. When you disable the responsibility, the main server will start polling VCS repositories.
If you have commit hooks configured on the main server, no changes in hooks are required: the hooks will continue working if the VCS polling is delegated to the secondary node.
Upgrade & Downgrade
It is recommended that the main TeamCity server and all secondary nodes have the same version. Read more in Multinode Setup.
Authentication & License
The main and secondary nodes operate under the same license.
Secondary nodes use the same authentication settings as the main server.
Secondary notes use the same global settings (path to artifacts, version control settings, and so on) as the main server.
You can import projects to the main server, as usual. Secondary nodes will detect the imported data in the runtime, without restarting.
Projects cannot be imported on secondary servers.
Secondary nodes have access to all plugins enabled on the main server. If you enable a plugin on the main server, you need to reload secondary nodes so they can use this plugin.
Currently, the following bundled plugins are disabled on secondary nodes:
Investigations Auto Assigner
Install Agent on remote host (agent push)
The TeamCity clean-up task runs on the main TeamCity server only. In a multinode configuration, as well as in a single node configuration, the task can run while the secondary servers are handling their operations.
Backup & Restore
The backup through the TeamCity web interface can be done on the main TeamCity server only. The backup from the command line can be done on both the main server and the secondary nodes.
The restore operation can be done on either of the nodes, but only if all servers using the TeamCity database and Data Directory are stopped.