{"id":43072,"date":"2023-01-27T07:28:48","date_gmt":"2023-01-04T04:55:52","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/"},"modified":"2024-04-29T11:41:59","modified_gmt":"2024-04-29T03:41:59","slug":"%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/","title":{"rendered":"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09"},"content":{"rendered":"<h2>\u6211\u60f3\u8981\u505a\u7684\u4e8b\u60c5 (W\u01d2 zu\u00f2 de<\/h2>\n<p>\u4f7f\u7528Ansible\u6765\u81ea\u52a8\u5316\u4ee5\u4e0b\u64cd\u4f5c\uff1a<br \/>\n&#8211; \u5b89\u88c5MySQL<br \/>\n&#8211; \u521b\u5efa\u6570\u636e\u5e93\u7528\u6237<br \/>\n&#8211; \u521b\u5efa\u6570\u636e\u5e93<br \/>\n&#8211; \u4ece\u53e6\u4e00\u4e2a\u6570\u636e\u5e93\u4e2d\u63d0\u53d6\u5e76\u6062\u590d\u6570\u636e<\/p>\n<h2>\u6267\u884c\u73af\u5883<\/h2>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">OS: OS X Yosemite (10.11.6)<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Vagrant: 1.8.5<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Virtualbox: 5.1.6 r110634<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Ansible: 2.1.2.0<\/ul>\n<h2>1. \u51c6\u5907\u5404\u79cd\u5de5\u5177\uff08\u5982\u679c\u5df2\u7ecf\u5b89\u88c5\u5219\u4e0d\u9700\u8981\uff09<\/h2>\n<p>\u8fd9\u91cc\u6709\u5199\u7740\u3002 .)<\/p>\n<h4>\u7b2c\u4e00\u6b65\uff1a\u5b89\u88c5Homebrew\u3002<\/h4>\n<h4>\u6b65\u9aa42\uff1a\u5b89\u88c5Homebrew Cask<\/h4>\n<h4>\u6b65\u9aa43. \u5b89\u88c5VirtualBox\u3002<\/h4>\n<h4>\u7b2c\u56db\u6b65\uff1a\u5b89\u88c5Vagrant<\/h4>\n<h4>\u7b2c\u4e94\u6b65\u3002\u5b89\u88c5Vagrant-vbguest\u63d2\u4ef6\u3002<\/h4>\n<h4>\u7b2c\u516d\u6b65\uff1a\u5b89\u88c5Ansible<\/h4>\n<h2>2. \u521b\u5efa Vagrantfile<\/h2>\n<p>\u8fd9\u4e9b\u4fe1\u606f\u5728\u8fd9\u9644\u8fd1\u6216\u8fd9\u91cc\u5199\u7740\u3002<\/p>\n<p>\u81f3\u6b64\u4e3a\u6b62\u7684\u611f\u89c9\u5dee\u4e0d\u591a<\/p>\n<pre class=\"post-pre\"><code>Vagrant.configure(\"2\") do |config|\r\n\r\n  config.vm.box = \"puppetlabs\/centos-6.6-64-nocm\"\r\n  config.vm.box_url = \"https:\/\/atlas.hashicorp.com\/puppetlabs\/boxes\/centos-6.6-64-nocm\/versions\/1.0.3\/providers\/virtualbox.box\"\r\n\r\n  config.ssh.insert_key = false\r\n  config.hostmanager.enabled = true\r\n  config.hostmanager.manage_host = true\r\n\r\n  # create db server\r\n  config.vm.define :\"db\" do |host|\r\n    host.vm.hostname = \"db\"\r\n    host.vm.network :private_network, ip: \"192.168.34.21\", netmask: \"255.255.255.0\"\r\n    host.vm.network :private_network, ip: \"192.168.33.21\", virtualbox__intnet: \"mv\"\r\n    # ansible\r\n    host.vm.provision \"ansible\" do |ansible|\r\n      ansible.playbook = \"provisioning\/dbservers.yml\"\r\n      ansible.inventory_path = \"provisioning\/hosts\"\r\n      ansible.limit = 'all'\r\n    end\r\n  end\r\nend\r\n<\/code><\/pre>\n<h2>\u521b\u5efaAnsible\u4efb\u52a1<\/h2>\n<h4>\u6b65\u9aa41. \u53c2\u8003\u6700\u4f73\u5b9e\u8df5\uff0c\u521b\u5efa\u76ee\u5f55\u548c\u6587\u4ef6<\/h4>\n<pre class=\"post-pre\"><code>roles\/\r\n   hosts\r\n   dbservers.yml\r\n   common\/\r\n      tasks\/\r\n         main.yml\r\n   database\/\r\n      handlers\/\r\n         main.yml\r\n      tasks\/\r\n         main.yml\r\n         mysql.yml\r\n         restore.yml\r\n      vars\/\r\n         main.yml\r\n<\/code><\/pre>\n<h2>\u7f16\u5199Ansible\u7684Playbook<\/h2>\n<h4>\u6b65\u9aa41. \u4e3b\u529e\u65b9<\/h4>\n<pre class=\"post-pre\"><code>[dbservers]\r\n127.0.0.1 ansible_ssh_private_key_file=.vagrant\/machines\/db\/virtualbox\/private_key ansible_ssh_user=vagrant\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa42\uff1adbservers.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- hosts: dbservers\r\n  become: true\r\n  roles:\r\n    - common\r\n    - database\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa43. \u5e38\u89c1\/\u4efb\u52a1\/main.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- name: change timezone\r\n  command: cp -p \/usr\/share\/zoneinfo\/Japan \/etc\/localtime\r\n- name: remove all rules from iptables\r\n  command: \/sbin\/iptables -F\r\n- name: iptables stop\r\n  service: name=iptables state=stopped\r\n- name: iptables off\r\n  command: \/sbin\/chkconfig iptables off\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa44. \u6570\u636e\u5e93\/\u5904\u7406\u7a0b\u5e8f\/main.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- name: enable mysql launch settings\r\n  command: \/sbin\/chkconfig mysqld on\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa45. \u6570\u636e\u5e93\/\u4efb\u52a1\/main.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- include: mysql.yml\r\n- include: restore.yml\r\n<\/code><\/pre>\n<h4>\u7b2c6\u6b65\uff1a\u6570\u636e\u5e93\/\u4efb\u52a1\/mysql.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- name: MySQL5.1\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\uff09\u524a\u9664\r\n  yum: name=mysql* state=absent\r\n- name: install repository\r\n  yum: name=http:\/\/dev.mysql.com\/get\/mysql-community-release-el6-5.noarch.rpm state=present\r\n- name: MySQL5.6\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\r\n  yum: name={{ item }} state=present\r\n  with_items:\r\n    - mysql\r\n    - mysql-devel\r\n    - mysql-server\r\n    - mysql-utilities\r\n    - MySQL-python\r\n  notify:\r\n    - enable mysql launch settings\r\n- name: start MySQL\r\n  service: name=mysqld state=started enabled=yes\r\n- name: \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u4f5c\u6210\r\n  mysql_db: db={{ item }} state=present encoding=utf8\r\n  with_items: \"{{ dbnames }}\"\r\n- name: \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u30e6\u30fc\u30b6\u4f5c\u6210\uff08\u6a29\u9650\u3082\u4ed8\u4e0e\u3059\u308b\uff09\r\n  mysql_user: &gt;\r\n    name={{ dbuser }}\r\n    password=\"{{ dbpass }}\"\r\n    host={{ item[0] }}\r\n    priv={{ item[1] }}.*:ALL\r\n    append_privs=yes\r\n    state=present\r\n  with_nested:\r\n    - \"{{ hosts }}\"\r\n    - \"{{ dbnames }}\"\r\n<\/code><\/pre>\n<h4>\u7b2c\u4e03\u6b65\uff1a\u6570\u636e\u5e93\/\u4efb\u52a1\/\u6062\u590d.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\n- name: \u30c0\u30f3\u30d7\u30d5\u30a1\u30a4\u30eb\u4f5c\u6210(\u30c7\u30fc\u30bf\u306f\u5225\u306eDB\u304b\u3089\u53d6\u3063\u3066\u304f\u308b)\r\n  mysql_db: &gt;\r\n    login_host={{ remotehost }}\r\n    login_user={{ dbuser }}\r\n    login_password={{ dbpass }}\r\n    name={{ item }}\r\n    target=\/tmp\/{{ item }}.dump\r\n    state=dump\r\n  with_items: \"{{ dbnames }}\"\r\n- name: \u30ea\u30b9\u30c8\u30a2\r\n  mysql_db: name={{ item }} target=\/tmp\/{{ item }}.dump state=import\r\n  with_items: \"{{ dbnames }}\"\r\n- name: \u30c0\u30f3\u30d7\u30d5\u30a1\u30a4\u30eb\u524a\u9664\r\n  file: path=\/tmp\/{{ item }}.dump state=absent\r\n  with_items: \"{{ dbnames }}\"\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa47. \u6570\u636e\u5e93\/\u53d8\u91cf\/\u4e3b\u8981.yml<\/h4>\n<pre class=\"post-pre\"><code>---\r\ndbuser: &lt;DB\u30e6\u30fc\u30b6\u540d&gt;\r\ndbpass: &lt;DB\u30e6\u30fc\u30b6\u306e\u30d1\u30b9\u30ef\u30fc\u30c9&gt;\r\nremotehost: &lt;\u30c7\u30fc\u30bf\u53d6\u5f97\u5143\u306eIP&gt;\r\nhosts:\r\n  - \"localhost\"\r\n  - \"192.168.33.20\"\r\ndbnames:\r\n  - &lt;restore\u3059\u308bDB\u540d&gt;\r\n  - &lt;restore\u3059\u308bDB\u540d&gt;\r\n<\/code><\/pre>\n<h2>5. \u68c0\u67e5\u52a8\u4f5c\u662f\u5426\u6b63\u786e<\/h2>\n<h4>\u7b2c\u4e00\u6b65\uff1a\u521b\u5efa\u865a\u62df\u673a<\/h4>\n<pre class=\"post-pre\"><code>$ vagrant up\r\n<\/code><\/pre>\n<h4>\u7b2c\u4e8c\u6b65\uff1a\u9a8c\u8bc1\u52a8\u4f5c<\/h4>\n<p>\u53ea\u8981\u80fd\u8fde\u63a5\u5230\u6570\u636e\u5e93\u5c31\u53ef\u4ee5\u3002(Zhi yao neng lian jie dao shu ju ku jiu ke yi.)<\/p>\n<h2>6. \u9644\u8d601\uff1a\u540c\u65f6\u4f7f\u7528no-data\uff08-d\uff09<\/h2>\n<p>\u7531\u4e8emysql_db\u6a21\u5757\u65e0\u6cd5\u6307\u5b9adump\u9009\u9879\uff0c\u56e0\u6b64\u9700\u8981\u4f7f\u7528shell\u6765\u6267\u884c\u3002\u8bf7\u6ce8\u610f\uff0c\u4f7f\u7528\u547d\u4ee4\u65f6\u65e0\u6cd5\u4f7f\u7528&#8221;&gt;&#8221;\u7b26\u53f7\u3002<\/p>\n<pre class=\"post-pre\"><code>- name: create no-data dump files\r\n  shell: mysqldump -h {{ remotehost }} -u {{ dbuser }} -p{{ dbpass }} {{ item }} -d &gt; \/tmp\/{{ item }}.dump\r\n  with_items: \"{{ nodatadbs }}\"\r\n<\/code><\/pre>\n<p>\u5728\u6267\u884c&#8221;\u30ea\u30b9\u30c8\u30a2&#8221;\uff08Restore\uff09\u7b49\u64cd\u4f5c\u65f6\uff0c\u53ef\u4ee5\u4f7f\u7528&#8221;Jinja2 filters&#8221;\u4e2d\u7684&#8221;union&#8221;\u51fd\u6570\u6765\u7f16\u5199\u826f\u597d\u7684\u4ee3\u7801\u3002<\/p>\n<pre class=\"post-pre\"><code>- name: restore databases\r\n  mysql_db: name={{ item }} target=\/tmp\/{{ item }}.dump state=import\r\n  with_items: \"{{ dbnames | union(nodatadbs) }}\"\r\n<\/code><\/pre>\n<h2>7. \u5305\u62ec View \u7684\u6570\u636e\u5e93\u652f\u6301<\/h2>\n<p>\u5982\u679c\u76ee\u6807\u6570\u636e\u5e93\u4e2d\u5305\u542b\u89c6\u56fe\uff0c\u6839\u636e\u5b9a\u4e49\u8005\u7684\u8bbe\u7f6e\u53ef\u80fd\u65e0\u6cd5\u8bbf\u95ee\uff0c\u56e0\u6b64\u5728\u8fd8\u539f\u4e4b\u524d\u9700\u8981\u8fdb\u884c\u66ff\u6362\uff08\u4ec5\u5f53\u66ff\u6362\u6ca1\u6709\u95ee\u9898\u65f6\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code>- name: edit dump files\r\n  replace: dest=\/tmp\/{{ item }}.dump regexp='&lt;\u7f6e\u63db\u524d&gt;`@`%' replace={{ dbuser }}`@`localhost\r\n  with_items: \"{{ dbnames }}\"\r\n<\/code><\/pre>\n<h2>8. \u9644\u8d60\u54c13\uff1a\u517c\u5bb9Windows<\/h2>\n<p>\u7531\u4e8eWindows\u65e0\u6cd5\u5b89\u88c5Ansible\uff0c\u56e0\u6b64\u9700\u8981\u5728\u865a\u62df\u673a\u4e0a\u8fd0\u884c\u3002<\/p>\n<h4>\u6b65\u9aa41. \u6dfb\u52a0$script<\/h4>\n<pre class=\"post-pre\"><code>$script = &lt;&lt;SCRIPT\r\n\r\nif ! [ `which ansible` ]; then\r\n    yum update -y\r\n    yum install -y http:\/\/ftp.iij.ad.jp\/pub\/linux\/fedora\/epel\/6\/x86_64\/epel-release-6-8.noarch.rpm\r\n    sed -i -e \"s\/enabled *= *1\/enabled=0\/g\" \/etc\/yum.repos.d\/epel.repo\r\n    yum install --enablerepo=epel -y ansible\r\nfi\r\n\r\nansible-playbook -i \/vagrant\/provisioning\/hosts \/vagrant\/provisioning\/dbservers.yml\r\n\r\nSCRIPT\r\n<\/code><\/pre>\n<h4>\u6b65\u9aa42. \u7f16\u8f91 provision<\/h4>\n<p>\u7f16\u8f91\u4e4b\u524d<\/p>\n<pre class=\"post-pre\"><code>host.vm.provision \"ansible\" do |ansible|\r\n  ansible.playbook = \"provisioning\/dbservers.yml\"\r\n  ansible.inventory_path = \"provisioning\/hosts\"\r\n  ansible.limit = 'all'\r\nend\r\n<\/code><\/pre>\n<p>\u7f16\u8f91\u540e<\/p>\n<pre class=\"post-pre\"><code>config.vm.provision \"shell\", inline: $script\r\n<\/code><\/pre>\n<p>mysql_db\u6a21\u5757\u771f\u65b9\u4fbf\u5440\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6211\u60f3\u8981\u505a\u7684\u4e8b\u60c5 (W\u01d2 zu\u00f2 de \u4f7f\u7528Ansible\u6765\u81ea\u52a8\u5316\u4ee5\u4e0b\u64cd\u4f5c\uff1a &#8211; \u5b89\u88c5MySQL &#038; [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-43072","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528ansible\u521b\u5efamysql\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\" \/>\n<meta property=\"og:description\" content=\"\u6211\u60f3\u8981\u505a\u7684\u4e8b\u60c5 (W\u01d2 zu\u00f2 de \u4f7f\u7528Ansible\u6765\u81ea\u52a8\u5316\u4ee5\u4e0b\u64cd\u4f5c\uff1a &#8211; \u5b89\u88c5MySQL &amp; [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528ansible\u521b\u5efamysql\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-01-04T04:55:52+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T03:41:59+00:00\" \/>\n<meta name=\"author\" content=\"\u6587, \u7fd4\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6587, \u7fd4\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/\",\"name\":\"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-01-04T04:55:52+00:00\",\"dateModified\":\"2024-04-29T03:41:59+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c\",\"name\":\"\u6587, \u7fd4\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g\",\"caption\":\"\u6587, \u7fd4\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/wenxiang\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528ansible\u521b\u5efamysql\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09","og_description":"\u6211\u60f3\u8981\u505a\u7684\u4e8b\u60c5 (W\u01d2 zu\u00f2 de \u4f7f\u7528Ansible\u6765\u81ea\u52a8\u5316\u4ee5\u4e0b\u64cd\u4f5c\uff1a &#8211; \u5b89\u88c5MySQL & [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528ansible\u521b\u5efamysql\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-01-04T04:55:52+00:00","article_modified_time":"2024-04-29T03:41:59+00:00","author":"\u6587, \u7fd4","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6587, \u7fd4","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"3 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/","name":"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-01-04T04:55:52+00:00","dateModified":"2024-04-29T03:41:59+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528Ansible\u521b\u5efaMySQL\u73af\u5883\uff08\u9644\u52a0\u5956\u52b1\uff09"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c","name":"\u6587, \u7fd4","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g","caption":"\u6587, \u7fd4"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/wenxiang\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8ansible%e5%88%9b%e5%bb%bamysql%e7%8e%af%e5%a2%83%ef%bc%88%e9%99%84%e5%8a%a0%e5%a5%96%e5%8a%b1%ef%bc%89\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43072","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=43072"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43072\/revisions"}],"predecessor-version":[{"id":85065,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43072\/revisions\/85065"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=43072"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=43072"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=43072"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}