It's possible to use JetPatch when you are working with local repositories . Here is the full guide on how to setup your environemnt and make sure all repositories are configured correctly and available for Jetpatch usage.
Please note that the instructions below are for setting up local repositories and are not related to JetPatch functionality.
Preconditions:
- Make sure your local repository server is registered to RHEL
- Local repository storage requirements are based on the number of endpoints connecting to the repo (specifically the /var/www mount point)
- Each operating system should have its own repository server. (i.e Repo for each of the following - RHEL 7, RHEL 6, CentOS 7..)
- Local repository must have Internet connectivity
Before we start:
1. Please take under considuration the 'repo-sync' command, which might take 9-10 hours to complete.
2. If you are familiar with repositories needed in your organization, other than the suggested below, configure them the exact same way. For example, if you need a RHEL 6.7 only repo vs 6.X, see RHEL official documentation.
Local Repository Setup
Step 1: Setup Nginx on Repository Server
1. First start by installing Nginx HTTP server from the EPEL repository using the YUM package manager as follows.
yum install epel-release
yum install nginx
2. Once you have installed Nginx web server, you can start it for the first time and enable it to start automatically at system boot.
service nginx start
3. Next, you need to open port 80 and 443 to allow web traffic to Nginx service, update the system firewall rules to permit inbound packets on HTTP and HTTPS using the commands below.
sudo iptables -I INPUT -p tcp -m tcp --dport 443 -j ACCEPT
sudo iptables -I INPUT -p tcp -m tcp --dport 80 -j ACCEPT
service iptables save
Step 2: Creating a local repository
1. Install the "yum-utils" and "createrepo" packages on the registered system.
yum install yum-utils createrepo httpd
2. Create directories for your repositories
mkdir /var/www/html/rhel6
mkdir /var/www/html/rhel6
mkdir /var/www/html/rhel6/main
mkdir /var/www/html/rhel6/server
mkdir /var/www/html/rhel6/dts
mkdir /var/www/html/rhel6/dts2
mkdir /var/www/html/rhel6/rhscl
3. Enable all relevant repositories (these are also the repo_id for the next step):
subscription-manager repos --enable=rhel-6-server-optional-rpms
subscription-manager repos --enable=rhel-6-server-rpms
subscription-manager repos --enable=rhel-server-dts-6-rpms
subscription-manager repos --enable=rhel-server-dts2-6-rpms
subscription-manager repos --enable=rhel-server-rhscl-6-rpms
4. Once all the repositories have been enabled, run the following commands:
reposync --gpgcheck -l --repoid=rhel-6-server-optional-rpms --download_path=/var/www/html/rhel6/server --downloadcomps --download-metadata
reposync --gpgcheck -l --repoid=rhel-6-server-rpms --download_path=/var/www/html/rhel6/main --downloadcomps --download-metadata
reposync --gpgcheck -l --repoid=rhel-server-dts-6-rpms --download_path=/var/www/html/rhel6/dts --downloadcomps --download-metadata
reposync --gpgcheck -l --repoid=rhel-server-dts2-6-rpms --download_path=/var/www/html/rhel6/dts2 --downloadcomps --download-metadata
reposync --gpgcheck -l --repoid=rhel-server-rhscl-6-rpms --download_path=/var/www/html/rhel6/rhscl --downloadcomps --download-metadata
5. Create repo command:
Once the packages have been downloaded all that is needed is the createrepo command below for each repo (example for RHEL6):
touch /var/www/html/rhel6/server/comps.xml
createrepo -v /var/www/html/rhel6/server/ -g comps.xml
createrepo -v /var/www/html/rhel6/main/
createrepo -v /var/www/html/rhel6/dts/
createrepo -v /var/www/html/rhel6/dts2/
createrepo -v /var/www/html/rhel6/rhscl/
Note: The -g comps.xml is only needed for the server repo.
6. Configure the updateinfo.xml file :
run the following commands:
-------------------------------
REPOSITORY CONFIG FOR rhel-6-server-optional-rpms REPO to "server" FOLDER:
==================
rm -rf /var/www/html/rhel6/server/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-6-server-optional-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/server/repodata/
gzip -d /var/www/html/rhel6/server/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/server/repodata/*-updateinfo.xml /var/www/html/rhel6/server/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/server/repodata/updateinfo.xml /var/www/html/rhel6/server/repodata/
-------------------------------
REPOSITORY CONFIG FOR rhel-6-server-rpms REPO to "Main" FOLDER:
==================
rm -rf /var/www/html/rhel6/main/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-6-server-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/main/repodata/
gzip -d /var/www/html/rhel6/main/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/main/repodata/*-updateinfo.xml /var/www/html/rhel6/main/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/main/repodata/updateinfo.xml /var/www/html/rhel6/main/repodata/
-------------------------------
REPOSITORY CONFIG FOR rhel-server-rhscl-6-rpms REPO to "rhscl" FOLDER:
==================
rm -rf /var/www/html/rhel6/rhsc/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-server-rhscl-6-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/rhscl/repodata/
gzip -d /var/www/html/rhel6/rhscl/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/rhscl/repodata/*-updateinfo.xml /var/www/html/rhel6/rhscl/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/rhscl/repodata/updateinfo.xml /var/www/html/rhel6/rhscl/repodata/
7. To enable viewing of repositories and packages in them, via a web browser, create a Nginx server block which points to the root of your repositories as shown.
vim /etc/nginx/conf.d/repos.conf
Add the following configuration ot file repos.conf.
server {
listen 80;
server_name repos.test.lab; #change test.lab to your real domain or IP address
root /var/www/html/;
location / {
index index.php index.html index.htm;
autoindex on; #enable listing of directory index
}
}
8. Restart nginx service:
service nginx restart
Create Script and Cron Job to Update Your Repositories (on repository server only)
1. Create a script named update-repository.sh and put it in /usr/local/bin with the following contents:
vi /usr/local/bin/update-repository.sh
echo Update script started at $(date) >> /var/log/update-repository.log
reposync --gpgcheck -l --repoid=rhel-6-server-rpms --download_path=/var/www/html/rhel6/main --downloadcomps --download-metadata
createrepo --update /var/www/html/rhel6/main/
reposync --gpgcheck -l --repoid=rhel-6-server-optional-rpms --download_path=/var/www/html/rhel6/server --downloadcomps --download-metadata
createrepo --update /var/www/html/rhel6/server/
reposync --gpgcheck -l --repoid=rhel-server-dts-6-rpms --download_path=/var/www/html/rhel6/dts --downloadcomps --download-metadata
createrepo --update /var/www/html/rhel6/dts/ \\
reposync --gpgcheck -l --repoid=rhel-server-dts2-6-rpms --download_path=/var/www/html/rhel6/dts2 --downloadcomps --download-metadata
createrepo --update /var/www/html/rhel6/dts2/
reposync --gpgcheck -l --repoid=rhel-server-rhscl-6-rpms --download_path=/var/www/html/rhel6/rhscl --downloadcomps --download-metadata
createrepo --update /var/www/html/rhel6/rhscl/
rm -rf /var/www/html/rhel6/server/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-6-server-optional-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/server/repodata/
gzip -d /var/www/html/rhel6/server/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/server/repodata/*-updateinfo.xml /var/www/html/rhel6/server/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/server/repodata/updateinfo.xml /var/www/html/rhel6/server/repodata/
rm -rf /var/www/html/rhel6/main/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-6-server-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/main/repodata/
gzip -d /var/www/html/rhel6/main/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/main/repodata/*-updateinfo.xml /var/www/html/rhel6/main/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/main/repodata/updateinfo.xml /var/www/html/rhel6/main/repodata/
rm -rf /var/www/html/rhel6/rhsc/repodata/*updateinfo*
cp /var/cache/yum/x86_64/6Server/rhel-server-rhscl-6-rpms/*-updateinfo.xml.gz /var/www/html/rhel6/rhscl/repodata/
gzip -d /var/www/html/rhel6/rhscl/repodata/*-updateinfo.xml.gz
mv /var/www/html/rhel6/rhscl/repodata/*-updateinfo.xml /var/www/html/rhel6/rhscl/repodata/updateinfo.xml
modifyrepo /var/www/html/rhel6/rhscl/repodata/updateinfo.xml /var/www/html/rhel6/rhscl/repodata/
echo Update script ended at $(date) >> /var/log/update-repository.log
chmod 600 /usr/local/bin/update-repository.sh
2. Create a file in /etc/cron.d and name it update-repository with the following content (where the @weekly parameter stands for the interval).
3. Update the crontab to run the update-repository.sh every week - Edit /etc/cron.d/update-repository with the following line:
@weekly root /usr/local/bin/update-repository.sh
Setting Up Client Servers
Note: The following steps should be performed on all client servers that are configured to sync with the local repositories. We highly recommend using our run-task capabilities, to easily distribute the configurations.
- Disable all current repositories in the Local Repository server by running disable-all-repos.sh attachement on the client server.
1. Create a .repo file that will be added to the /etc/yum.repos.d directory on every server using the repositories. That file should look similar to the following file.
vi /etc/yum.repos.d/name_of_repo_file.repo
[mainrepo]
name = rhel-6-server-rpms
baseurl = http://hostname_or_ip_address_of_repository/main
gpgcheck = 0
enabled = 1
priority=1
[server]
name = rhel-6-server-optional-rpms
baseurl = http://hostname_or_ip_address_of_repository/server
gpgcheck = 0
enabled = 1
priority=1
[dts]
name = rhel-server-dts-6-rpms
baseurl = http://hostname_or_ip_address_of_repository/dts
gpgcheck = 0
enabled = 1
priority=1
[dts2]
name = rhel-server-dts2-6-rpms
baseurl = http://hostname_or_ip_address_of_repository/dts2
gpgcheck = 0
enabled = 1
priority=1
[rhscl]
name = rhel-server-rhscl-6-rpms
baseurl = http://hostname_or_ip_address_of_repository/dts2
gpgcheck = 0
enabled = 1
priority=1
YUM setup validation
In order to validate the process works successfully, run on a client machine the following:
yum clean all
yum list updates
You should be able to view all relevant updates that can be installed (exposed from repository we have setted in step1)
Then, try to install an update ( run: yum instal update_name)
If the update is installed successdfully, it means the process has been completed as expected.
Run script on all endpoint servers
We highly recommend configuring adding the repo-file using our run task capabilities. In order to do so, please follow the 'Configure Local Repository on all Client Servers' instructions.
We're all Set!
Error Handling
1. If you're encountering the following error when installaing nginx: yum error “Cannot retrieve metalink for repository: epel. Please verify its path and try again” updating ContextBroker
Solution:
Edit both /etc/yum.repos.d/epel.repo and /etc/yum.repos.d/epel-testing.repo files commenting all entries starting with mirrorlist=... and uncommenting all the entries starting with baseurl=.... ;
run again yum install nginx
2. If files do not appear when viewing the repositories from web browser:
Solution: restorecon -R /var/www/html/repos
3. If you have any issues such as Error 404 page not found it might be related to your nginx configuration. To view nginx errors go to /var/log/nginx/error.log . Errors might be related to nginx configuration (etc/nginx/conf.d/repos.conf). Please make sure you configured it properly.
4. In case you have changed configurations (in repo server) do not forget to run 'yum clean all' and 'yum repolist all' afterwards. If you have changed nginx conf. restart nginx service.
Comments
0 comments
Please sign in to leave a comment.