У меня есть две виртуальные машины, работающие в VMWare. Один использует OpenStack, а другой — обычная ненадежная машина. В OpenStack я запускаю образ Ubuntu с MongoDB 4.4. Моя MongoDB работает с «частным» интерфейсом и плавающим «публичным» IP-адресом. Проблема сейчас в том, что мне нужно подключить мою ненадежную машину к MongoDB. Я хочу добавить в него данные с помощью Python.
У меня есть готовый код, но я получаю ошибки соединения по тайм-ауту. Я предполагаю, что это потому, что MongoDB работает на локальном хосте, но как мне запустить его на плавающем IP-адресе? Есть ли способ или мне нужно добавить интерфейс в openstack? Я попытался добавить интерфейс в «общедоступную» подсеть, но он говорит о статусе «ВНИЗ», и я понятия не имею, как его активировать. Прямо сейчас я могу пропинговать Ubuntu MongoDB только со своей шаткой виртуальной машины, но это все. Помощь! НЕКОТОРЫЙ код Python:
# MongoDB setup
client = pymongo.MongoClient("mongodb://192.168.1.53:27017/")
database = client["climdns"]
collection = database["dnszone"]
...
# Add record to MongoDB
collection.insert_one({
'fqdn': domain,
'ipv4': ipv4,
'last_change': datetime.now(),
'user': {
'email': email,
'id': user_id
}
})
...
def login(provider_name):
# We need response object for the WerkzeugAdapter.
response = make_response()
# Log the user in, pass it the adapter and the provider name.
result = authomatic.login(WerkzeugAdapter(request, response), provider_name)
# If there is no LoginResult object, the login procedure is still pending.
if result:
if result.user:
# We need to update the user to get more info.
result.user.update()
if result.user.email and result.user.id:
headers = {'email': result.user.email, 'user_id': result.user.id}
response = requests.post('http://localhost:5001/add_dns', headers=headers)
return response.json()
return gui_index()
монгод.конф:
# mongod.conf
# for documentation of all options, see:
# http://docs.mongodb.org/manual/reference/configuration-options/
# Where and how to store data.
storage:
dbPath: /var/lib/mongodb
journal:
enabled: true
# engine:
# mmapv1:
# wiredTiger:
# where to write logging data.
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/mongod.log
# network interfaces
net:
port: 27017
bindIp: 0.0.0.0
ошибка в Rocky VM после запуска кода:
pymongo.errors.ServerSelectionTimeoutError: 192.168.1.53:27017: timed out, Timeout: 30s, Topology Description: <TopologyDescription id: 6611380c7c10562e5bc268a4, topology_type: Unknown, servers: [<ServerDescription ('192.168.1.53', 27017) server_type: Unknown, rtt: None, error=NetworkTimeout('192.168.1.53:27017: timed out',)>]>
Оказывается, решение было очень простым: я просто забыл добавить порт MongoDB в группу безопасности, которая была на моем экземпляре. Вот почему тайм-аут продолжался. Не забудьте проверить брандмауэр!!