- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有没有办法使用 Dockerfile 更改 MySQL 上的 IP?我的应用程序有问题。
我有这样的配置:
let ormConfig: any;
if (process.env.NODE_ENV === 'test') {
// test environment database should be drop every time. so synchronize should be true for this config
ormConfig = {
type: 'mysql',
host: '0.0.0.0',
// host: 'localhost', // not needed if run on docker
username: 'root',
password: 'password',
database: 'test_db',
synchronize: true,
dropSchema: true,
entities: ['src/models/**/*.ts']
};
} else {
ormConfig = {
type: 'mysql',
host: 'db', // docker service database name
// host: 'localhost', // not needed if run on docker
// port: 3306, // not needed if run on docker
username: 'root',
password: 'password',
database: 'development_db',
synchronize: false,
logging: true,
entities: ['src/models/**/*.ts'],
migrations: ['db/migrations/**/*.ts'],
subscribers: ['src/subscribers/**/*.ts'],
cli: {
entitiesDir: 'src/models',
migrationsDir: 'db/migrations',
subscribersDir: 'src/subscribers'
}
};
}
export = ormConfig;
我正在使用 typeorm 作为我的 ORM。在其他 block 上,我有一个主机名db
,如果我正在使用我的应用程序,则在连接到我的数据库时它可以工作,但是当我尝试运行迁移时,我必须将主机更改为0.0.0.0。 0.0
,发现是因为docker MySQL容器(server_db镜像):
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
aaaa4d178537 server_server "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:8000->8000/tcp server_server_1
e5021687b86b server_db "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:3306->3306/tcp, 33060/tcp server_db_1
我只是厌倦了在迁移之前和之后不断地改变它。
有什么想法只使用本地主机吗?或者像 1.2.3.456
这样的自定义 IP?
这也是我的 docker-compose 文件:
version: "3.3"
services:
db:
build: ./db
restart: always
env_file:
- .env
ports:
- "3306:3306"
networks:
- app_network
server:
depends_on:
- "db" # this is important for sql connection. it has to wait for mysql to establish connection then run this bish
build: .
command: ["npm", "run", "dev"]
restart: always
ports:
- "8000:8000"
volumes:
- /server/node_modules/ # added this because of bcrypt elm error
- type: bind
source: .
target: /server # this name is from dockerfile workdir
networks:
- app_network
networks:
app_network:
volumes:
app_volume:
和我的数据库 Dockerfile
FROM mysql:8.0.18
EXPOSE 3306
COPY ./init_db.sql /docker-entrypoint-initdb.d/
回答@ckaserer的问题:
Where are you running the migration from? e.g. are you trying to connect from your workstation/docker host to the mysql container?
我通过 npm 使用命令 npm run migration:run
Any error logs you can share?
错误提示无法连接到db:3306
,这就是为什么我必须将其更改为0.0.0.0:3306
。
Can you clarify your migration workflow and where it fails? (including from which system it is executed. e.g. container x, workstation,..)
迁移发生在使用 typeOrm cli 的容器外部,我创建一个迁移,然后 cli 将检查我的 ormconfig.ts
并检查 else block 的类型和主机。 (我不确定这是否是你的要求)
如果我运行迁移,则会出现以下错误:
错误:getaddrinfo ENOTFOUND db db:3306
IP:端口是问题所在。咕噜咕噜。
最佳答案
检查容器运行时是否可以在主机上重现以下内容。
只需执行docker-compose up
尝试像这样从主机连接到您的 mysql 数据库
mysql -u root -ppassword -h 127.0.0.1
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 8.0.18 MySQL Community Server - GPL
Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
#+--------------------+
| Database |
+--------------------+
| development_db |
| information_schema |
| mysql |
| performance_schema |
| production_db |
| sys |
| test_db |
+--------------------+
7 rows in set (0.01 sec)
这里有一些事情。首先,你的ormconfig.ts
对于容器内的应用程序来说是正确的。你的server
容器想要连接到 db
容器。这样可行。在您的 docker-compose 文件中,您明确公开了 db
端口3306
到主机上的所有可用接口(interface)。您可以通过运行来检查
docker container ls
8b5c4dc41892 ggpo-server_server "docker-entrypoint.s…" 47 hours ago Up 5 seconds 0.0.0.0:8000->8000/tcp ggpo-server_server_1
a0ca405d8020 ggpo-server_db "docker-entrypoint.s…" 47 hours ago Up 6 seconds 0.0.0.0:3306->3306/tcp, 33060/tcp ggpo-server_db_1
这意味着您的数据库在 127.0.0.1:3306
的主机上可用。和 [HOST-IP]:3306
。这就是为什么之前的 mysql connect 与 127.0.0.1
一起工作的原因。 .
我们开始吧!就像我说的,你的 ormconfig.ts
对于容器内的应用程序来说是正确的 - 但如果您想从主机连接到数据库则不正确。您的主机不知道 DNS 名称 db
所以你的ormconfig.ts
不管用。为了从您的主机访问它,您需要 host: localhost
,为了让您的服务器正常工作,您需要 host: db
。但你不能同时设置两者。因此,您可能需要引入某种额外的环境配置来区分这两种情况。
if (process.env.NODE_ENV === 'test') {
// test environment database
...
} else if (process.env.NODE_ENV === 'local') {
// new config with host: localhost
} else {
// default
}
<小时/>
不,您不能为 dockerfile 中的镜像分配固定 IP。这会破坏可移植性和可扩展性,因为 IP 需要是唯一的。
host
绑定(bind)到0.0.0.0
在这种情况下你需要什么。它将 mysql 服务绑定(bind)到所有可用的网络接口(interface)。在你的情况下localhost
和 app_network
在容器内。
因此,您可以从app_network
内的任何其他容器访问该容器。或者您可以进入 db
容器并通过 mysql 连接直接执行迁移到 localhost
.
你就快到了。您已经有了 db
的端口暴露定义。在你的docker-compose.yml
。
version: "3.3"
services:
db:
ports:
- "3306:3306"
但是,您无法从外部通过容器名称访问该容器。端口暴露定义port
告诉 docker 转发您的主机收到的任何流量 3306
到db
港口容器3306
。也就是说,您可以访问 db
使用您的主机 IP 或主机名从您的主机上,因为您已经在运行容器的计算机上,所以您可以简单地使用 localhost
或127.0.0.1
在您的迁移中。
您需要更改用于迁移的 ormconfig.ts。特别是host
输入值来自 db
至 localhost
.
{
"type": "mysql",
"host": "localhost",
"port": 3306,
"username": "test",
"password": "test",
"database": "test"
}
这应该可以解决您的问题。
<小时/>镜像未运行,因此没有 IP 分配。
但是,您可以在 docker-compose.yml 中为容器指定固定 IP,如下所示
version: '2'
services:
app:
image: busybox
command: ifconfig
networks:
app_net:
ipv4_address: 172.18.18.10
networks:
app_net:
driver: bridge
driver_opts:
com.docker.network.enable_ipv6: "false"
ipam:
driver: default
config:
- subnet: 172.18.18.0/24
gateway: 172.18.18.1
IP 是特定网络中系统的唯一标识符。那么当您想要有 2 个 app
实例时会发生什么? ?
docker-compose up --scale app=2
Creating network "playground_app_net" with driver "bridge"
Creating playground_app_1 ... done
Creating playground_app_2 ... error
ERROR: for playground_app_2 Cannot start service app: b'Address already in use'
ERROR: for app Cannot start service app: b'Address already in use'
ERROR: Encountered errors while bringing up the project.
Docker 告诉您 IP 地址已在第一次实例化 app
时被使用。并且不能再次分配。
关于mysql - 如何使用 Dockerfile 更改 MySQL 上的默认 IP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59639845/
给定的输入是192.168.3.78/27 输入可以是任意C类ip地址,以上ip为例进行尝试 预期输出应显示从 192.168.3.65 到 192.168.3.94 的所有 IP如下 192.168
您好,我是一名 javascript 菜鸟,正在为 IP 范围编写验证器。例如,1.1.1.1-2.2.2.2 是一个有效范围,但我想确保第一个 IP 不大于第二个 IP。 2.2.2.2-1.1.1
在 MySQL 数据库中存储多种 IP 类型的最佳方式是什么: - 单一 IP (123.123.123.123) - IP 范围 (123.123.123.1 - 123.123.123.121)
所以我有一个带有子网的 IP:8.8.8.0/24 我如何将其转换为 8.8.8.0 和 8.8.8.255(实际上是它们的 ip2long 结果) 在 PHP 和 JavaScript 中 最佳答案
我有 Windows7 作为我的基本操作系统。最重要的是,我在 Ubuntu 上安装了 Virtual Box。我希望 ubuntu 获得与我的基本操作系统(Win7)相同的 IP 地址。我如何实现这
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
阅读后List of IP Space used by Facebook : “真实”列表是最后一个答案,但我想知道 Igy(答案标记为解决方案)如何通过将连续的类添加到更大的类中来大幅缩小列表(通过
我正在开发一个 web 应用程序,我已经在我的本地主机中创建了这个项目,但是网络用户需要访问我的项目,我不想给他们一个不友好的 ip 地址,所以我想用户访问一个名称例子 http://myprojec
有人可以向我解释 Azure 在逻辑应用程序的出站 IP 地址之间不同的新方式之间的区别。 我认为文档在对该问题的正确解释方面非常精简。读起来听起来好像 IP 地址在逻辑应用程序中具有完全相同的作用。
我正在尝试熟悉一个项目中java中的数据报系统,目前,我们只使用UDP包。 为了发送消息,我们在 DatagramPacket 上设置目标 IP。 /* * The fields o
我有一个 Java 服务器,当我获得连接时,我需要检查 IP 是本地 IP 还是公共(public) IP。当它是我自己的本地 IP 时,我可以检测到它,但我在使用其他本地 IP 时遇到了一些问题。J
所以我在网上看到了很多例子,这些例子展示了如果你知道起始 IP 和结束 IP 如何获得完整的 IP,但我需要的是在提供后告诉我完整的 IP 范围带有起始 IP 和所需 IP 地址数的代码。 因此,例如
我创建了一个 python 项目,用于扫描 IP 范围(即 x.y.z.0/24)并返回在线主机列表。它将在线主机列表保存到仅包含 IP 的文件中(即 ['192.168.0.1'、'192.168.
如果用户的 ip 在某个 IP 范围之间,我正在使用重定向。但是,我正在使用多个 ip 范围,所以我想知道执行此操作的最佳方法。我目前正在使用它来重定向, 但是如果 IP 范围是 72.122.166
好的,现在是星期五下午,我度过了漫长的一周,希望能得到一些帮助!目前,我有一个 IP 范围列表,如下所示: List ipRanges = new List(); ipRanges.Add(new I
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
下面是我的 CloudFormation 模板的片段,用于将弹性 IP 地址与网络接口(interface)的主 IP 相关联: "MyInterfaceSelfEipAssociat
我在 Azure 上创建了 Python 函数,该函数调用外部 API 服务,该服务仅允许访问白名单 IP。 根据 Microsoft 文档 ( https://learn.microsoft.com
我在 Azure 上创建了 Python 函数,该函数调用外部 API 服务,该服务仅允许访问白名单 IP。 根据 Microsoft 文档 ( https://learn.microsoft.com
我在我的 CentOS 5 x86_64 中使用 IP 别名。为简化此示例:IP 地址 A 是 eth0 地址,IP 地址 B 是 eth0:0地址。我有 2 个 Apache 实例(版本 2.2.3
我是一名优秀的程序员,十分优秀!