{"id":2909,"date":"2024-01-31T15:31:01","date_gmt":"2024-01-31T07:31:01","guid":{"rendered":"https:\/\/199604.com\/?p=2909"},"modified":"2024-01-31T15:31:01","modified_gmt":"2024-01-31T07:31:01","slug":"docker-zabbix%e4%bd%bf%e7%94%a8odbc%e7%9b%91%e6%8e%a7%e6%95%b0%e6%8d%ae%e5%ba%93","status":"publish","type":"post","link":"https:\/\/199604.com\/2909","title":{"rendered":"Docker-Zabbix\u4f7f\u7528ODBC\u76d1\u63a7\u6570\u636e\u5e93"},"content":{"rendered":"<h1>Docker-Zabbix\u4f7f\u7528ODBC\u76d1\u63a7\u6570\u636e\u5e93<\/h1>\n<h2>\u524d\u8a00<\/h2>\n<p>\u56e0\u6700\u8fd1\u5bb9\u5668\u5316\u6539\u9020\uff0czabbix-server\u4e5f\u5728k8s\u96c6\u7fa4\u90e8\u7f72\u4e86\uff0c\u4f46\u5b98\u7f51\u5bb9\u5668\u672a\u90e8\u7f72\u90e8\u5206<code>unixODBC<\/code>\u9a71\u52a8\u7a0b\u5e8f\uff0c\u9700\u8981\u81ea\u884c\u91cd\u65b0\u6784\u5efa\u65b0\u5bb9\u5668\u3002<\/p>\n<p>\u56e0\u6b64\u672c\u6b21\u5bf9<code>PostgreSQL<\/code>\u3001<code>MySQL<\/code>\u3001<code>Oracle<\/code>\u4e09\u4e2a\u6570\u636e\u5e93\u8fdb\u884c<code>unixODBC<\/code>\u9a71\u52a8\u90e8\u7f72\u3002<\/p>\n<h2>\u8fc7\u7a0b<\/h2>\n<p>\u56e0\u57fa\u7840\u955c\u50cf\u4f7f\u7528\u7684\u662f\u5e95\u5c42\u7cfb\u7edf\u4e3aCentos8\u7248\u672c\uff0c\u56e0\u6b64\u9700\u8981\u63d0\u524d\u51c6\u5907\u597d\u5bf9\u5e94<code>RPM\u5305<\/code><\/p>\n<p>\u5176\u4ed6\u7cfb\u7edf\u53ef\u53c2\u8003\u5b98\u65b9\u6587\u6863\uff1a<code>https:\/\/www.zabbix.com\/documentation\/6.0\/zh\/manual\/config\/items\/itemtypes\/odbc_checks<\/code><\/p>\n<p>\u63d0\u524d\u4e0b\u8f7d\u4e00\u4e0brpm\u5305\uff1a<\/p>\n<pre><code class=\"language-shell \">mysql-connector-odbc-8.3.0-1.el8.x86_64.rpm\noracle-instantclient-basic-21.3.0.0.0-1.x86_64.rpm\noracle-instantclient-devel-21.3.0.0.0-1.x86_64.rpm\noracle-instantclient-odbc-21.3.0.0.0-1.x86_64.rpm\noracle-instantclient-sqlplus-21.3.0.0.0-1.x86_64.rpm\npostgresql-odbc-10.03.0000-2.el8.src.rpm\n<\/code><\/pre>\n<p>Dockerfile\u91cd\u65b0\u6784\u5efa\u5185\u5bb9\u5982\u4e0b\uff1a<\/p>\n<pre><code class=\"language-dockerfile \">FROM zabbix\/zabbix-server-pgsql:6.0.25-centos\nMAINTAINER GLJ\n\nUSER root\n\n# \u5b89\u88c5 ODBC\u9a71\u52a8\ncopy mysql-connector-odbc-8.3.0-1.el8.x86_64.rpm \/tmp\/mysql-connector-odbc-8.3.0-1.el8.x86_64.rpm\n#copy postgresql-odbc-10.03.0000-2.el8.src.rpm \/tmp\/postgresql-odbc-10.03.0000-2.el8.src.rpm\ncopy oracle-instantclient-basic-21.3.0.0.0-1.x86_64.rpm \/tmp\/oracle-instantclient-basic-21.3.0.0.0-1.x86_64.rpm\ncopy oracle-instantclient-devel-21.3.0.0.0-1.x86_64.rpm \/tmp\/oracle-instantclient-devel-21.3.0.0.0-1.x86_64.rpm\ncopy oracle-instantclient-odbc-21.3.0.0.0-1.x86_64.rpm \/tmp\/oracle-instantclient-odbc-21.3.0.0.0-1.x86_64.rpm\ncopy oracle-instantclient-sqlplus-21.3.0.0.0-1.x86_64.rpm \/tmp\/oracle-instantclient-sqlplus-21.3.0.0.0-1.x86_64.rpm\n\nRUN sed -i.bak \\\n        -e 's|^mirrorlist=|#mirrorlist=|' \\\n        -e 's|^#baseurl=|baseurl=|' \\\n        -e 's|http:\/\/mirror.centos.org|https:\/\/mirrors.aliyun.com|' \\\n        \/etc\/yum.repos.d\/CentOS-*.repo \\\n    &amp;&amp; yum install -y unixODBC* postgresql-odbc  \\\n    &amp;&amp; yum install -y \/tmp\/mysql-connector-odbc-8.3.0-1.el8.x86_64.rpm \\\n    &amp;&amp; yum install -y \/tmp\/oracle-instantclient-basic-21.3.0.0.0-1.x86_64.rpm \\\n    &amp;&amp; yum install -y \/tmp\/oracle-instantclient-devel-21.3.0.0.0-1.x86_64.rpm \\\n    &amp;&amp; yum install -y \/tmp\/oracle-instantclient-odbc-21.3.0.0.0-1.x86_64.rpm \\\n    &amp;&amp; yum install -y \/tmp\/oracle-instantclient-sqlplus-21.3.0.0.0-1.x86_64.rpm \\\n    &amp;&amp; rm -f \/tmp\/mysql-connector-odbc-8.3.0-1.el8.x86_64.rpm \\\n    &amp;&amp; rm -f \/tmp\/oracle-instantclient-*.rpm\n\nUSER 1997\n<\/code><\/pre>\n<h3>\u6784\u5efa\u65b0\u955c\u50cf<\/h3>\n<p>\u4e0a\u6b21\u6240\u6709\u6587\u4ef6\u5230\u4e00\u6587\u4ef6\u5939\u6267\u884c<\/p>\n<p><code>docker build -t reg-hub.glj.com\/zabbix\/zabbix-server-pgsql:6.0.25-centos-db .<\/code><\/p>\n<h2>k8s\u5f15\u5165<code>odbcinst.ini<\/code>\u548c<code>odbc.ini<\/code>\u6587\u4ef6\u5185\u5bb9<\/h2>\n<pre><code class=\"language-yaml \">apiVersion: v1\nkind: ConfigMap\nmetadata:\n  namespace: zabbix\n  name: zabbix-server-config\n  labels:\n    app: zabbix-server\n    name: zabbix-server\ndata:\n  odbc.ini: |-\n\n    [postgres28]\n    Driver = PostgreSQL\n    Description = Test on PostgreSQL\n    Database = zabbix\n    Servername = 10.10.10.10\n    UserName = zabbix\n    Port = 5432\n    ReadOnly = No\n    Password = zabbix123\n\n\n  odbcinst.ini: |-\n    [PostgreSQL]\n    Description=ODBC for PostgreSQL\n    Driver=\/usr\/lib\/psqlodbcw.so\n    Setup=\/usr\/lib\/libodbcpsqlS.so\n    Driver64=\/usr\/lib64\/psqlodbcw.so\n    Setup64=\/usr\/lib64\/libodbcpsqlS.so\n    FileUsage=1\n\n    [MySQL]\n    Description=ODBC for MySQL\n    Driver=\/usr\/lib\/libmyodbc5.so\n    Setup=\/usr\/lib\/libodbcmyS.so\n    Driver64=\/usr\/lib64\/libmyodbc5.so\n    Setup64=\/usr\/lib64\/libodbcmyS.so\n    FileUsage=1\n\n    [FreeTDS]\n    Description=Free Sybase &amp; MS SQL Driver\n    Driver=\/usr\/lib\/libtdsodbc.so\n    Setup=\/usr\/lib\/libtdsS.so\n    Driver64=\/usr\/lib64\/libtdsodbc.so\n    Setup64=\/usr\/lib64\/libtdsS.so\n    Port=1433\n\n    [MariaDB]\n    Description=ODBC for MariaDB\n    Driver=\/usr\/lib\/libmaodbc.so\n    Driver64=\/usr\/lib64\/libmaodbc.so\n    FileUsage=1\n\n    [MySQL ODBC 8.3 Unicode Driver]\n    DRIVER=\/usr\/lib64\/libmyodbc8w.so\n    UsageCount=1\n\n    [MySQL ODBC 8.3 ANSI Driver]\n    DRIVER=\/usr\/lib64\/libmyodbc8a.so\n    UsageCount=1\n\n    [Oracle]\n    Description=ODBC for Oracle\n    Driver=\/usr\/lib\/oracle\/21\/client64\/lib\/libsqora.so.21.1\n<\/code><\/pre>\n<p>\u5206\u522b\u7ed1\u5b9a\u5230\u5bb9\u5668<code>\/etc\/odbc.ini<\/code>\u548c<code>\/etc\/odbcinst.ini<\/code>\u8def\u5f84<\/p>\n<p><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qn.199604.com\/typoraImg\/image-20240131151137275.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/qn.199604.com\/typoraImg\/image-20240131151137275.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"image-20240131151137275\" \/><\/div><\/p>\n<p>\u5927\u81f4\u8fc7\u7a0b\u5df2\u5b8c\u6210\uff0c\u5269\u4e0b\u5373\u53ef\u8fdb\u884czabbix\u9875\u9762\u914d\u7f6e\u76d1\u63a7\uff0c\u914d\u7f6e\u53c2\u8003\uff1a<a class=\"wp-editor-md-post-content-link\" href=\"https:\/\/medium.com\/@jieshiun\/%E5%A6%82%E4%BD%95%E5%9C%A8-zabbix-%E4%B8%AD%E4%BD%BF%E7%94%A8-postgresql-by-odbc-%E7%9B%A3%E6%8E%A7%E7%AF%84%E6%9C%AC-cabbb22be3e0\">Zabbix \u4e2d\u4f7f\u7528 PostgreSQL by ODBC<\/a><\/p>\n<h2>\u53c2\u8003<\/h2>\n<p>1.<code>https:\/\/www.zabbix.com\/documentation\/6.0\/zh\/manual\/config\/items\/itemtypes\/odbc_checks<\/code><\/p>\n<p>2.<code>https:\/\/github.com\/zabbix\/zabbix-docker\/issues\/80<\/code><\/p>\n<p>3.<code>https:\/\/blog.csdn.net\/ethnicitybeta\/article\/details\/126729825<\/code><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Docker-Zabbix\u4f7f\u7528ODBC\u76d1\u63a7\u6570\u636e\u5e93 \u524d\u8a00 \u56e0\u6700\u8fd1\u5bb9\u5668\u5316\u6539\u9020\uff0czabbix-server\u4e5f\u5728k8s [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[383],"tags":[372],"class_list":["post-2909","post","type-post","status-publish","format-standard","hentry","category-zabbix","tag-zabbix"],"_links":{"self":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2909","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/comments?post=2909"}],"version-history":[{"count":1,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2909\/revisions"}],"predecessor-version":[{"id":2910,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/posts\/2909\/revisions\/2910"}],"wp:attachment":[{"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/media?parent=2909"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/categories?post=2909"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/199604.com\/wp-json\/wp\/v2\/tags?post=2909"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}