I am trying to Connect Both Public Cloud SQL and Data Fusion instances but ended up receiving the 403 error.
Failed to create connection to database via connection string: jdbc:postgresql:///analytics?cloudSqlInstance=chatbot-dev-356403:europe-central2:chatbot&socketFactory=com.google.cloud.sql.postgres.SocketFactory and arguments: {user=chatbot-dev}. Error: GoogleJsonResponseException: 403 Forbidden { "code" : 403, "errors" : [ { "domain" : "global", "message" : "The client is not authorized to make this request.", "reason" : "notAuthorized" } ], "message" : "The client is not authorized to make this request." }. Make sure you specify the correct connection properties.
I am not sure if it's a permission issue. I have the following permissions in my service account added during Data fusion instance creation:
roles/storage.admin
roles/datafusion.admin
roles/datafusion.runner
roles/datafusion.serviceAgent
roles/dataproc.worker
roles/cloudsql.admin
roles/cloudsql.client
Also I can see another service account in the instance but Not sure if I have to add permissions to this account too?
Have you followed the instructions here: https://cloud.google.com/data-fusion/docs/how-to/reading-from-postgresql ?
I had the same problem because I was looking to the Service Account and Dataproc service account defined in the Data Fusion instance, but those are not the service accounts requiring permissions.
I had to:
After performing those actions everything worked fine.
Please let us know if that works out for you.