Branch versioning
This page is about the Esri ArcGIS Enterprise "Branch Versioning".
Caveat emptor
You might not find this written elsewhere, but heed it you must.
ArcGIS Pro 2.8 works only with Enterprise 10.9
ArcGIS Pro 2.9 works only with Enterprise 10.9.1
There are only a few free resources because this is a relatively new thing. Esri currently has only a paid 1 day $750 class. Nonetheless, I persist.
I am not going to explain what it is here because that's described elsewhere. This page is my notes made while experimenting. See the resources section below for detailed information.
Versioning
Basically, put the data into a feature class in an Enterprise geodatabase.
Share it as a Map Image Layer with Features enabled to a Portal.
Add it to an ArcGIS Pro project
Create a version aka a branch
Edit
Whee!
History grows forevermore, there is no way to remove it "at this time." I consider this a good thing.
Putting a feature class into versioning
- Upgrade ArcGIS to 10.9. Fix all the things this breaks.
- Try, with existing SQL Server. Discover that SQL Server we installed with ArcGIS 10.4 (or so) is TOO OLD.
- Switch to another database on a newer server, one that's maintained.
- In meantime, ArcGIS Pro 2.9 came out. Install that.
- Discover 2.9 requires a new license manager. Install it, corrupt existing licenses, call Esri. (This takes all concurrent licenses offline for a few hours.)
- Try again. I am working with my "repeater sites" feature class.
- In Pro (now at 2.9!) make a connection to the db and import the feature class.
- Remove the layer importing automatically added to the current map for you without asking, because it creates a schema lock.
- Enable Versioning + Branch. (Catalog->Databases->Properties->Manage)
- Add global ids to repeater_sites. Looks like this will happen in Pro now when I enable Branch Versioning.
- Enable editor tracking. This is also part of Pro.
- Sadly time will be in UTC. Option for local time is disabled with Branch Versioning.
- Quit and restart ArcGIS Pro at this point, because it's doing the things where every tool is "zoom to infinity".
- Restarting does not help, it's still stuck. Ha ha ha so fun!! It's the Esri webroot anti-virus bug!!
- Pound on the keyboard until the problem goes away. I am not kidding. This is the solution.
- Change database connection from catalog too, not sure what this does but it seems important.
Okay pressing on, glue the Portal and the SQL Server together, also known as Manage Registered Data Stores
THERE IS A BUG HERE THAT COST ME MOST OF TODAY. THIS PROCESS CREATES A CONNECTION STRING THAT YOU CANNOT EDIT THAT IS WRONG.
Do NOT go to Share tab, and "Data Stores". This is USELESS because it will only create traditional version connection and that won't work here.
Connection strings
- Created by official process, does not work:
SERVER=cc-thesql;INSTANCE=sde:sqlserver:cc-thesql;DBCLIENT=sqlserver;DB_CONNECTION_PROPERTIES=cc-thesql;DATABASE=gis_sandbox;USER=sde;VERSION=sde.DEFAULT;AUTHENTICATION_MODE=DBMS
- Works:
SERVER=cc-thesql;INSTANCE=sde:sqlserver:cc-thesql;DBCLIENT=sqlserver;DB_CONNECTION_PROPERTIES=cc-thesql;DATABASE=gis_sandbox;USER=sde;AUTHENTICATION_MODE=DBMS;BRANCH=sde.DEFAULT
Instead attempt to publish the layer, which fails because your database is not registered. Then click on the ellipsis next to error 00231 and select "Register Data Source With Server".
- Select "Portal Items" (the default)
- "Add"
- Meaningful title like "gis_sandbox" which is also the database name in my case.
- A good tag, like "Test"
- A Portal folder like "GIS_Sandbox"
- The database connection will be "SQL Server", and use database authentication with user "sde" and your password.
- Set "Share with" which in my case is "GIS Team"
- It should figure out the name of your one and only server. Pick it and do "Validate"
- "Create" (or later on you can do changes and use "Save")
- I can go into Portal now and see a Data Store object right where I expected it.. in a new folder called GIS_Sandbox.
- Create a web layer
- In the Map Properties, under General, turn on "Allow assignment of unique numeric IDs for sharing web layers.
- In the Edit tab, make sure editing is turned off.
- Pick a layer and use "Share As Web Layer". I used my "points of interest".
- It's going to be a Map Image layer, with Feature access enabled.
- Under "Configuration" select Version Management and select a Dedicated Instance, not Shared.
I used second method to create a new version, the Versioning Tab.
Options for publishing services
Q. I don't really want to publish each layer as a separate services, what happens if I publish an entire map and set feature access on it?
A. You won't be able to edit features. It creates one feature service that has 4 layers in it. It also still publishes the Map Image Layer with 4 layers in it. (I don't know why I want the MIL, all I want is the feature layers.) There will be feature access for each layer but it will be published in Server as a single service.
Q. How can I see what versions are available and use them on the web? For instance show a version that has Proposed Repeater Sites in it. Not a separate service just a version of the Repeater Sites feature layer with some new repeaters in it. Then I could share the layer out on a web map and get feedback before committing the sites.
A. ?
Q. Can I see more than one version on the map at the same time?
Resources
In the Esri training site there is one 62 minute video called "Version Management with ArcGIS" that you can watch that gives a pretty good overview at the start then dives in way too deep. Skip the middle and go for the Q/A at the end.
Version management API (ref doc)
Blogs
Managing your Branch Versions in Experience Builder