The RPM installation bundles Distribution and all its dependencies. It is provided as native RPM packages, where Distribution and its dependencies must be installed separately. Use this if you are automating installations.
Before you proceed, see System Requirements for information on supported platforms, supported browsers, and other requirements.
Complete the following steps to install the product.
Extract the contents of the compressed archive, and go to the extracted folder.
tar -xvf jfrog-distribution-<version>-rpm.tar.gz cd jfrog-distribution-<version>-rpm
Install PostgreSQL.
Already have a PostgreSQL installation?
Set your PostgreSQL connection details in the Shared Configurations section of the
$JFROG_HOME/distribution/var/etc/system.yaml
file.Install Redis.
Install Distribution.
rpm -Uvh --replacepkgs ./distribution/distribution.rpm
You must run as a root user.
Customize the product configuration.
Set the Artifactory connection details.
Customize the PostgreSQL Database connection details. (optional)
Set any additional configurations (for example: ports, node id) using the Distribution System YAML file .
Start and manage the Distribution service.
systemd OS
systemctl start|stop distribution.service
systemv OS
service distribution start|stop|status|restart
Access Distribution from your browser at:
http://<jfrogUrl>/ui/
.Go to the Distribution tab in the Application module in the UI.
Check the Distribution log.
tail -f $JFROG_HOME/distribution/var/log/console.log
Configure log rotation of the console log
The
console.log
file can grow quickly since all services write to it. For more information, see configure the log rotation.
Third Party Applications for Distribution
PostgreSQL for Distribution
You must install PostgreSQL before you proceed with the installation of Distribution.
PostgreSQL for RPM
Install PostgreSQL.
Run the following commands from the extracted
jfrog-distribution-<version>/rpm
directory.# Use PostgreSQL RPMs with el6 when installing on Centos 6 and RHEL 6 and use postgresql13-13.3-1 packages # Use PostgreSQL RPMs with el8 when installing on Centos 8 and RHEL 8 mkdir -p /var/opt/postgres/data rpm -ivh --replacepkgs ./third-party/postgresql/libicu-50.2-3.el7.x86_64.rpm (only AWS instance) rpm -ivh --replacepkgs ./third-party/postgresql/postgresql13-libs-13.3-5PGDG.rhel7.x86_64.rpm rpm -ivh --replacepkgs ./third-party/postgresql/postgresql13-13.3-5PGDG.rhel7.x86_64.rpm rpm -ivh --replacepkgs ./third-party/postgresql/postgresql13-server-13.3-5PGDG.rhel7.x86_64.rpm chown -R postgres:postgres /var/opt/postgres export PGDATA="/var/opt/postgres/data" export PGSETUP_INITDB_OPTIONS="-D /var/opt/postgres/data" # For centos 7&8 / rhel 7&8 sed -i "s~^Environment=PGDATA=.*~Environment=PGDATA=/var/opt/postgres/data~" /lib/systemd/system/postgresql-13.service systemctl daemon-reload /usr/pgsql-13/bin/postgresql-13-setup initdb # For centos 6 / rhel 6 sed -i "s~^PGDATA=.*~PGDATA=/var/opt/postgres/data~" /etc/init.d/postgresql-13 service postgresql-13 initdb Replace "ident" and "peer" with "trust" in postgres hba configuration files ie /var/opt/postgres/data/pg_hba.conf
Configure PostgreSQL to allow external IP connections.
By default, PostgreSQL will only allow localhost clients communications. To enable different IP's to communicate with the database, you need to
configure the pg_hba.conf
file.The file is available at
/var/opt/postgres/data
.To grant all IPs access, add the following entry under the IPv4 local connections section.
host all all 0.0.0.0/0 trust
Add the following entry to
/var/opt/postgres/data
/postgresql.conf
.listen_addresses='*' port=5432
Start PostgreSQL.
systemctl start postgresql-<version>.service or service postgresql-<version> start
Set up the database and user.
Run the following commands to seed the tables and schema needed by Distribution.
sudo -u postgres psql -c "CREATE USER distribution WITH PASSWORD 'password';" sudo -u postgres psql -c "CREATE DATABASE distribution WITH OWNER=distribution ENCODING='UTF8';" sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE distribution TO distribution;" cp -f ./third-party/postgresql/createPostgresUsers.sh /tmp source /etc/locale.conf cd /tmp && su postgres -c "POSTGRES_PATH=/usr/pgsql-13/bin PGPASSWORD=postgres DB_PASSWORD=password bash /tmp/createPostgresUsers.sh"
Redis for Distribution
Redis Password Restrictions
Redis password should contain only alphanumeric characters and should not contain any special characters.
Redis RPM Installation
Run the following commands from the extracted jfrog-distribution-<version>-rpm
directory.
Use Redis RPMs with el6 when installing on Centos 6 and RHEL 6 Use Redis RPMs with el8 when installing on Centos 8 and RHEL 8 semodule -i ./third-party/redis/distribution-redis.pp rpm -ivh --replacepkgs ./third-party/redis/jemalloc-3.6.0-1.el7.x86_64.rpm rpm -ivh --replacepkgs ./third-party/redis/redis-6.0.5-1.el7.remi.x86_64.rpm service redis start # To verify if Redis is working. The command should return PONG. redis-cli -a password ping sed -i "s|# requirepass foobared|requirepass password|g" /etc/redis.conf echo "appendonly yes" >> /etc/redis.conf echo "appendfsync everysec" >> /etc/redis.conf sysctl vm.overcommit_memory=1 service redis restart