I think you may have come across this: https://github.com/blockstack/blockstack-core/pull/844 (please see the last comment). There’s a race condition in the code that can very rarely but with non-zero probability cause a zone file to get ignored by the subdomain system. I’m spinning up a node from genesis to verify that the above fix corrects the issue. In the mean time, if you do the following, you can rectify the issue on your node:
stop your node
move your ~/.blockstack-server/subdomains.db file out of the way
move your ~/.blockstack-server/backups/subdomains* files out of the way
restart your node
This should force your node to regenerate all of its subdomain state, and do so without triggering the race condition.