-
Notifications
You must be signed in to change notification settings - Fork 693
Photon RPM OSTree: 10 Remotes
In Chapter 3 we talked about the Refspec that contains a photon: prefix that is the name of a remote. When a Photon host is installed, a remote is added - which is the URL for an OStree repository that is the origin of the commits we are going to pull from and deploy filetrees. This remote is named photon, which may be confusing, because it's also the OS name and part of the Refspec (branch) path.
A host repo can be connected to more than one remote, however only one remote is the "active" one. We can list the remotes created so far, which brings back the expected result.
root@photon-host-def [ ~ ]# ostree remote list
photon
We can inquiry about the URL for that remote name, which for the default host is the expected Photon OS online repo.
root@photon-host-def [ ~ ]# ostree remote show-url photon
https://dl.bintray.com/vmware/photon/rpm-ostree/1.0
But where is this information stored? The repo's config file has it.
root@photon-host-def [ ~ ]# cat /ostree/repo/config
[core]
repo_version=1
mode=bare
[remote "photon"]
url=https://dl.bintray.com/vmware/photon/rpm-ostree/1.0
gpg-verify=false
If we execute the same command on the custom host we've installed, it's going to reveal the URL of the Photon server connected to during setup.
root@photon-host-cus [ ~ ]# ostree remote show-url photon
http://10.118.101.168
Since mapping name/url is stored in the repo's config file, in principle you can re-assign a different URL, connecting the host to a different server. The next upgrade will get the latest commit chain from the new server.
If we edit photon-host-def's repo config and replace the bintray URL by photon-srv1's IP address, all original packages in the original 1.0_minimal version will be preserved, but any new package change (addition, removal, upgrade) added after that (in 1.0_minimal.1, 1.0_minimal.2) will be reverted and all new commits from photon-srv1 (that may have same version) will be applied. This is because the two repos are identical copies, so they have the same original commit ID as a common ancestor, but they diverge from there.
This may create confusion and it's one of the reasons I insisted on creating your own scheme of versioning.
If the old and new repo have nothing in common (no common ancestor commit), this will undo even the original commit, so all commits from the new tree will be applied.
A better solution would be to add a new remote that will identify where the commits come from.
- Home
- Download Photon OS
- User Documentation
- FAQ
- Security Advisories
- Related Information