I want to use Vault <https://github.com/hashicorp/vault> to manage and 
rotate the usernames and passwords to my databases.

If I open a connection: db, err := sql.Open("mysql", "...."), and then 
later on, open a new connection due to the username/password being rotated: 
db, err = sql.Open("mysql", "...") //no new variables created,
will the original sql instance leak? I want to avoid having to force all 
current queries and executions on the old db to terminate using Close(), as 
I would need to have some mutex to act as a gatekeeper for all interactions 
with the database, which would be quite complex.

Ideally, I would prefer the following:
1. New username/password pair received and sql.Open() is called.
2. Old db instance is still being used by a few goroutines as they still 
hold references to the old sql instance.
3. Goroutines finishes and no longer hold references to the old sql 
instance. The old sql instance is GC'd. Is this possible without calling 
Close()?
4. New goroutines are launched and they use the new sql instance.

Cheers,
Francis

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to