Skip to main content

Cloud

Lync Server 2013 SQL Mirroring “Gotcha” – Must Read

For quite some time now, I’ve been working on a global design/deployment where there are multiple pools located throughout the globe.  Throughout this design, I’ve seen the flexibility of Lync Server 2013 at its very finest and gained a much better appreciation for how Lync Server was designed by the Product Team at Microsoft.  Due to the shear size of this particular design, I’ve seen Lync have to perform as advertised with not much margin for error.  There has been a few hiccups, but nothing that a little forward thinking or creative thinking couldn’t solve.  Now with all the praise given, I do have to say that some of my pain points along the way were not well documented by the folks at Microsoft, so I’ve had to discover a few things as I’ve pushed forward.
As we know, Lync 2013 introduced Mirroring as a replacement for Clustering in the great search for respectable Disaster Recovery.  Even though the Lync team’s selection of Mirroring was a much better practice than clustering, it did spawn a whole new argument; Why Mirroring over AlwaysOn?”.  Find yourself a SQL guy and have a nice debate. J  Since we are using Mirroring, we as Lync Consultants must learn all the new tip and tricks that SQL Mirroring brings to the table.  We now straddle that fine line of who owns the Mirror and how much SQL do we need to know to accomplish our goals.  With this particular design, the SQL Team was great to work with so I got to learn quite a bit along the way.  One thing I did learn, was the reason for this blog and I find it to be quite the Gotcha that TechNet failed to tell us.  I’ll also call out a few more things that I’ve learned with this such deployment.
Lessons Learned from my experience:
1.)    TechNet states you can use a single Witness for all your pools.  This is correct, but if you have multiple central sites, that Witness needs to be defined in each “Shared Components” under each central site or it will not show up as an option.
2.)    If you have deployed a Single SQL Server in the Topology then decide to come back and deploy a mirror at a later time, you cannot use “Install Databases” under your targeted Pool.  You must use either PowerShell or configure the Mirror in Topology then Publish the Topology.  This may have been permissions related, but nonetheless, it was the only way Mirroring after the fact worked for me.  Keep it in mind.
3.)    When an organization employs Role Separation and permissions in SQL are tightly monitored, it is very important that the DBAs setup the permissions appropriately between the Mirror Nodes and the witness.  In my experience, we had dedicated SQL Boxes which was not an issue as we had SA permissions, however, the Witness was a “Shared” SQL Box, so the permissions were tighter.  We could not configure the Witness from Topology unless we allowed the SQL Administrators to run Topology.  You may be able to get your permissions granted as necessary, but just keep in mind that the backend permissions when a mirror and witness are involved are very delicate.
4.)    Now to the biggest Gotcha I found.  When deploying Lync Mirroring in Topology, we as Lync Admins are tasked with configuring a Mirror “Port” for each instance.  The default is 5022 but this is configurable.  Each subsequent Instance on the same SQL box, must have a unique Port, so the next one could be 5025 as an example.  In the SQL world, this port is actually referred to as an “Endpoint”.  It’s still using a port, it’s just that the terminology is used differently as a SQL DBA.  If the endpoints are not defined by the SQL DBAs, we allow Lync to setup and configure the Port/Endpoint when we allow Lync to configure the Mirror.  Allowing Lync to deploy the Mirror is our recommended approach as we are not DBAs(This is where the whole argument of who owns the mirror comes into play).  During this setup stage the Mirror completes as expected and the port configured and we are happy.  Now assuming we as the Lync Consultant had a temporary account created for us to deploy Lync, this is where the problem is.  Inside of SQL, the Process ID (Owner of the endpoint) is the account used to create the Mirror.  If I deployed the Mirror as Domain\TempLyncADmin that account now owns the Endpoint.  When I leave as a consultant and they disable my account, that account is no longer valid, hence the Mirror will now not function.  The Process owner must be changed from the Account who configured the mirror from Lync, to the ID of the Instance.  My recommendation would be to have the SQL DBA configure the Endpoint prior to deployment and tell you want Endpoint/Port to use so they retain ownership.
Here is a snip-it from the SQL Architect I worked with explaining the situation:
“The first person who sets up sql server mirroring on an instance becomes the owner of the mirroring endpoints (this is the default behavior).
After setting up a mirror, the DBA will change the owner of the endpoint to the process account that runs the sql server services on the instance. We Do not want the endpoint owned by an individual’s login.
Once the ownership has been changed the service owners for all instances in this configuration (Mirror, principal, witness) are granted permissions to the endpoint.
 (The permissions are granted at the time the endpoint is created. However since we change the owner, we re-grant the permissions.)
Keep in mind moving forward that this process DOES NOT make the Lync Admin re-take ownership during Cumulative Updates to break and re-enable the mirror.  This is just a one time ownership configuration.
If you are a consultant and you’ve moved on since a deployment, I would recommend you revisit this with your client.  If you are an organization who did Lync yourself, I would recommend you review this and make sure your Endpoints are properly owned.

Thoughts on “Lync Server 2013 SQL Mirroring “Gotcha” – Must Read”

  1. Interesting post. Thanks Jason. Having just gone through a large deployment where I setup two Lync 2013 Sites, I wanted to check and make sure my customer was not in this situation. To determine ownership I ran the following SQL Query:
    SELECT e.name as mirror_endpoint_name, s.name AS login_name
    , p.permission_name, p.state_desc as permission_state, e.state_desc endpoint_state
    FROM sys.server_permissions p
    INNER JOIN sys.endpoints e ON p.major_id = e.endpoint_id
    INNER JOIN sys.server_principals s ON p.grantee_principal_id = s.principal_id
    WHERE p.class_desc = ‘ENDPOINT’ AND e.type_desc = ‘DATABASE_MIRRORING’
    This displayed the result:
    mirror_endpoint_name login_name permission_name permission_state endpoint_state
    Mirroring Domain\ServerSQL1$ CONNECT GRANT STARTED
    Mirroring Domain\ServerSQL2$ CONNECT GRANT STARTED
    Mirroring Domain\ServerSQL3$ CONNECT GRANT STARTED
    This would indicate the computer accounts for the SQL servers respectively have access to the mirroring endpoint. I was expecting the Lync account I used to setup the mirror would be listed here but it was not. Based on this I believe you should be okay. In the above case SQL1 is the Primary, SQL2 is the Mirror (where I ran the query) and SQL3 is the witness.
    In this installation we did not have any DBA’s make any changes to SQL permissions. We were using the default instance of SQL in all cases so perhaps this may factor into it. If there is another query you suggest to validate the endpoint ownership kindly advise.
    Thanks again for the post,
    Regards
    Dino

  2. Hey Dino,
    I’m not sure of the script the DBA’s ran at my current deployment, I’ll have to reach out and see what it was exactly and what the script is they ran to clean it up. So, in my scenario we had unique instances, but we were also running the instances under domain services accounts rather than local service or network service, so that could be yet another variable to check.

  3. Sanjeev Gandhi

    Hello Jason,
    Thanks for the nice post. I have a question on setting up mirroring with witness in multi central site. as you mentioned and TechNet also says we can use the single witness server for multiple pair of SQL server. But if we have multiple site, you mentioned we need to add the witness server in shared component and then it will show up as an option.
    Now my question is Do you think it would allow us to add the same witness server as shared component what we already used in Site 1? i don’t think it does, for me it fails with error saying “server name is already in use”
    Thanks,
    Sanjeev Gandhi

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Jason Sloan

I currently hold the Microsoft Certified Master on Lync Server 2010 certificatoin and work as a Senior Technical Consultant at Perficient, specializing in Unified Communications design and deployments. My history in IT dates back 15 years with all my experience coming primarily from Microsoft Technologies. I believe the Microsoft Unified Communiations community is a very close and talented group of engineers who genuinely enjoy the technologies and collaborating with one another to help the technologies dominate the marketplace.

More from this Author

Follow Us