{"id":36128,"date":"2023-07-28T17:16:47","date_gmt":"2023-06-04T23:45:11","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/"},"modified":"2024-04-30T15:46:20","modified_gmt":"2024-04-30T07:46:20","slug":"%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/","title":{"rendered":"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b"},"content":{"rendered":"<h1>\u76ee\u5f55<\/h1>\n<p>1. \u9996\u5148<br \/>\n2. \u73af\u5883<br \/>\n3. \u5b89\u88c5\u6b65\u9aa4<br \/>\n4. \u9047\u5230\u7684\u9519\u8bef<br \/>\n5. \u603b\u7ed3<\/p>\n<h1>URL\u7684\u53c2\u8003<\/h1>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Install via Devstack<\/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\">DevStack<\/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\">OpenStack Configuration<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">Welcome to kuryr-kubernetes\u2019s documentation!<\/ul>\n<h1>\u9996\u5148<\/h1>\n<p>\u4f60\u597d\u3002\u6211\u662f\u4e00\u4f4d\u65b0\u5458\u5de5\uff0c\u5165\u804c\u5927\u7ea6\u4e09\u4e2a\u6708\u4e86\u3002<\/p>\n<p>\u8fd9\u7bc7\u6587\u7ae0\u5c06\u5206\u4e3a\u591a\u4e2a\u7ae0\u8282\uff0c\u8bb0\u8f7d\u4e00\u4e2a\u5bf9NFV\u4e00\u8bcd\u4e00\u65e0\u6240\u77e5\u7684\u65b0\u4eba\u901a\u8fc7\u53c2\u8003DevStack\u7684\u5b89\u88c5\u8fdb\u884c\u4e86DevStack\u73af\u5883\u7684\u5b89\u88c5\uff0c\u5e76\u767b\u8bb0\u4e86OpenStack\u548cKubernetes\u4f5c\u4e3aVIM\u7684\u6b65\u9aa4\u4ee5\u53ca\u9047\u5230\u7684\u9519\u8bef\u3002<\/p>\n<ul class=\"post-ul\">\u7b2c 1 \u7ae0: \u3053\u306e\u8a18\u4e8b\u3067\u3059\u3002<\/ul>\n<p>\u6211\u5c06\u5c1d\u8bd5\u901a\u8fc7Devstack\u8fdb\u884c\u5b89\u88c5\u3002<\/p>\n<ul class=\"post-ul\">\u7b2c 2 \u7ae0: \u7d9a\u304f\u3002\u3002\u3002<\/ul>\n<p>\u6211\u5728\u6b64\u6b21\u5b89\u88c5\u8fc7\u7a0b\u4e2d\u6240\u8c03\u67e5\u7684\u672f\u8bed\u5df2\u603b\u7ed3\u5982\u4e0b\u3002<\/p>\n<h2>\u7f51\u7edc\u529f\u80fd\u865a\u62df\u5316 (Network Function Virtualization)<\/h2>\n<p>\u8fd9\u662f\u4e00\u79cd\u5728\u901a\u7528\u670d\u52a1\u5668\u7684\u865a\u62df\u5316\u57fa\u7840\u8bbe\u65bd\u4e0a\u4ee5\u8f6f\u4ef6\u5f62\u5f0f\u5b9e\u73b0\u7f51\u7edc\u529f\u80fd\u7684\u65b9\u5f0f\u3002<br \/>\nETSI\uff08\u6b27\u6d32\u7535\u4fe1\u6807\u51c6\u5316\u673a\u6784\uff09\u63d0\u5021\u7684NFV\u67b6\u6784\u4e2d\uff0c\u5c06\u5176\u5206\u4e3aVNF\u3001NFVI\u548cMANO\u4e09\u4e2a\u9886\u57df\u3002<\/p>\n<h3>VNF\uff08\u865a\u62df\u7f51\u7edc\u529f\u80fd\uff09<\/h3>\n<p>\u8fd9\u662f\u4e00\u4e2a\u4f5c\u4e3a\u865a\u62df\u673a\u8fd0\u884c\u7684\u7f51\u7edc\u8bbe\u5907\u3002<br \/>\n\u8fd9\u662f\u7528\u6765\u66ff\u4ee3\u73b0\u6709\u7f51\u7edc\u8bbe\u5907\u7684\u60f3\u6cd5\u3002<\/p>\n<h3>\u7f51\u7edc\u529f\u80fd\u865a\u62df\u5316\u57fa\u7840\u8bbe\u65bd (NFVI)<\/h3>\n<p>\u7528\u4e8e\u8fd0\u884cVNF\u7684\u7269\u7406\u8d44\u6e90\u548c\u865a\u62df\u5316\u529f\u80fd\u3002<br \/>\n\u5305\u62ec\u670d\u52a1\u5668\u3001\u5b58\u50a8\u7b49\u786c\u4ef6\u8d44\u6e90\u4ee5\u53ca\u7528\u4e8e\u865a\u62df\u5316\u7684\u865a\u62df\u673a\u76d1\u63a7\u7a0b\u5e8f\u3002<\/p>\n<h3>NFV MANO\uff08\u7ba1\u7406\u4e0e\u7f16\u6392\uff09<\/h3>\n<p>\u63d0\u4f9b\u786c\u4ef6\u8d44\u6e90\u3001\u8f6f\u4ef6\u8d44\u6e90\u3001VNF\u7ba1\u7406\u529f\u80fd\u548c\u7f16\u6392\u529f\u80fd\u3002<br \/>\n\u7531\u4ee5\u4e0b\u4e09\u4e2a\u529f\u80fd\u7ec4\u6210\u3002<\/p>\n<p>NFVO (NFV Orchestrator)<br \/>\n\u81ea\u52d5\u5316\u306e\u4e2d\u5fc3\u7684\u306a\u5f79\u5272\u3092\u62c5\u3044\u3001\u8907\u6570\u306e VNF \u304b\u3089\u69cb\u6210\u3055\u308c\u308b\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u30b5\u30fc\u30d3\u30b9\u306e\u30e9\u30a4\u30d5\u30b5\u30a4\u30af\u30eb\u3092\u7ba1\u7406\u3057\u3001\u30b7\u30b9\u30c6\u30e0\u5168\u4f53\u3092\u7d71\u5408\u7684\u306b\u904b\u7528\u3057\u307e\u3059\u3002<\/p>\n<p>VNFM (VNF Manager)<br \/>\nVNF \u304c\u5fc5\u8981\u306a\u30ea\u30bd\u30fc\u30b9\u3084 VNF \u306e\u30e9\u30a4\u30d5\u30b5\u30a4\u30af\u30eb\u3092\u7ba1\u7406\u3057\u307e\u3059\u3002<\/p>\n<p>VIM (Virtualized Infrastructure Manager)<br \/>\nNFVI \u3092\u5236\u5fa1\u3057\u307e\u3059\u3002<br \/>\nOpenStack \u3084 Kubernetes \u3068\u3044\u3063\u305f\u3082\u306e\u304c\u8a72\u5f53\u3057\u3001\u5fc5\u8981\u306a VM \u3084\u30ea\u30bd\u30fc\u30b9\u306e\u5272\u308a\u5f53\u3066\u3092\u884c\u3044\u307e\u3059\u3002<\/p>\n<h2>VNF\u63cf\u8ff0\u7b26 (VNF Descriptor)<\/h2>\n<p>\u8fd9\u662f\u4e00\u4e2a\u57fa\u4e8eTOSCA\u7684YAML\u683c\u5f0f\u7684\u6a21\u677f\uff0c\u76f8\u5f53\u4e8eVNF\u76ee\u5f55\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">TOSCA (Topology and Orchestration Specification for Cloud Applications)<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u30af\u30e9\u30a6\u30c9\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5411\u3051\u30c8\u30dd\u30ed\u30b8\u30fb\u30aa\u30fc\u30b1\u30b9\u30c8\u30ec\u30fc\u30b7\u30e7\u30f3\u306b\u95a2\u3059\u308b\u4ed5\u69d8\u3067\u3059\u3002<\/ul>\n<h2>\u67e5\u627e\u8005<\/h2>\n<p>NFVO\uff08NFV\u7f16\u914d\u5668\uff09\u548cVNFM\uff08VNF\u7ba1\u7406\u5668\uff09\u3002<\/p>\n<p>\u901a\u8fc7\u57fa\u4e8e\u76ee\u5f55\u5316\u7684\u7f51\u7edc\u670d\u52a1\uff08NSD\uff09\u548c\u76ee\u5f55\u5316\u7684\u865a\u62df\u7f51\u7edc\u529f\u80fd\uff08VNFD\uff09\uff0c\u901a\u8fc7\u57fa\u7840\u8bbe\u65bd\u9a71\u52a8\u7a0b\u5e8f\u5c06VNF\u53ca\u5176\u76f8\u5173\u7f51\u7edc\u90e8\u7f72\u5230VIM\u4e2d\u3002<\/p>\n<p>\u8ddf\u8e2a\u5668-\u5bfc\u5458\uff08tacker-conductor\uff09\u548c\u8ddf\u8e2a\u5668-\u670d\u52a1\u5668\uff08tacker-server\uff09\u662f\u7531MySQL\u8fdb\u7a0b\u7ec4\u6210\u7684\u3002<br \/>\nMySQL\u662f\u4e00\u4e2a\u6570\u636e\u5e93\uff0c\u8bb0\u5f55\u4e86\u6ce8\u518c\u7684VIM\u4fe1\u606f\u7b49\u3002<br \/>\n\u5728\u5b89\u88c5\u4e86DevStack\u73af\u5883\u540e\uff0c\u60a8\u4e5f\u53ef\u4ee5\u5b9e\u9645\u67e5\u770bMySQL\u7684\u5185\u5bb9\u3002<\/p>\n<h3>\u5bfc\u8f68\u5bfc\u7ebf<\/h3>\n<p>\u6307\u6325\u8005\u5728\u8fd9\u91cc\u7684\u610f\u601d\u662f\u6307\u5bfc\u5458\u3001\u5411\u5bfc\uff0c\u6216\u8005\u662f\u97f3\u4e50\u672f\u8bed\u4e2d\u7684\u6307\u6325\u8005\u3002\u56e0\u6b64\uff0c\u8fd9\u90e8\u5206\u662f\u6307\u8d1f\u8d23\u6267\u884cTacker\u63a5\u6536\u5230\u7684\u5904\u7406\u5e76\u62c5\u4efb\u5bf9VIM\u8fdb\u884cAPI\u5ba2\u6237\u7aef\u64cd\u4f5c\u7684\u89d2\u8272\u7684\u90e8\u5206\u3002<\/p>\n<h3>\u8ffd\u8e2a\u5668\u670d\u52a1\u5668<\/h3>\n<p>\u63a5\u53d7\u6765\u81eaNFVO\u548cVNF\u7684\u8bf7\u6c42\u3002<br \/>\n\u6839\u636e\u6240\u63a5\u6536\u7684\u8bf7\u6c42\uff0c\u5c06\u5176\u4f20\u9012\u7ed9tacker-conductor\u6216MySQL\u8fdb\u884c\u5904\u7406\u3002<\/p>\n<h1>\u73af\u5883<\/h1>\n<p>\u6211\u5728ESXi\u4e0a\u51c6\u5907\u4e86\u4ee5\u4e0b\u914d\u7f6e\u7684\u865a\u62df\u673a\u3002<br \/>\n\u6240\u4f7f\u7528\u7684\u64cd\u4f5c\u7cfb\u7edf\u662fUbuntu 20.04 LTS\u3002<\/p>\n<div>\n<div class=\"post-table\">\n\u81ea\u74b0\u5883\u63a8\u5968\u74b0\u5883CPU4 core4core \u4ee5\u4e0aRAM16GB16GB \u4ee5\u4e0aStorage160GB80GB \u4ee5\u4e0a<\/div>\n<\/div>\n<p>\u5728\u865a\u62df\u673a\u51c6\u5907\u5b8c\u6210\u540e\uff0c\u4f7f\u7528\u4ee5\u4e0b\u547d\u4ee4\u5c06\u5176\u66f4\u65b0\u5230\u6700\u65b0\u72b6\u6001\u5e76\u91cd\u65b0\u542f\u52a8\u3002<\/p>\n<pre class=\"post-pre\"><code>sudo apt-get update\r\nsudo apt-get upgrade\r\n<\/code><\/pre>\n<p>\u5982\u679c\u60a8\u7684\u7cfb\u7edf\uff08\u4f8b\u5982ESXi\uff09\u53ef\u4ee5\u4f7f\u7528\u5feb\u7167\u529f\u80fd\uff0c\u5efa\u8bae\u60a8\u5728\u6b64\u9636\u6bb5\u5c06\u5176\u8bb0\u5f55\u4e3a\u521d\u59cb\u72b6\u6001\u3002<\/p>\n<h1>\u5b89\u88c5\u6b65\u9aa4<\/h1>\n<p>\u8fd9\u4e2a\u8fc7\u7a0b\u5728\u672c\u73af\u5883\u4e0b\u6210\u529f\u5730\u5b89\u88c5\u5b8c\u6210\u4e86\u3002<br \/>\n\u5c06\u53d1\u751f\u7684\u9519\u8bef\u603b\u7ed3\u4e3a4\u4e2a\uff0c\u5373\u53d1\u751f\u7684\u9519\u8bef\u3002<\/p>\n<h2>\u5b89\u88c5Tacker<\/h2>\n<p>\u5b89\u88c5Tacker\u7684\u7b2c\u4e00\u6b65\u662f\u514b\u9686Devstack\u5e76\u51c6\u5907local.conf\u3002<\/p>\n<p>Devstack<br \/>\nOpenStack \u3092\u7c21\u5358\u306b\u30c7\u30d7\u30ed\u30a4\u3059\u308b\u305f\u3081\u306e\u30c4\u30fc\u30eb\u3067\u3059\u3002<\/p>\n<p>local.conf<br \/>\n\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u306b\u306f\u3001\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u306b\u5fc5\u8981\u306a\u3055\u307e\u3056\u307e\u306a\u69cb\u6210\u30aa\u30d7\u30b7\u30e7\u30f3\u304c\u542b\u307e\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<h3>\u521b\u5efaDevStack\u5b89\u88c5\u7528\u6237<\/h3>\n<p>\u521b\u5efa\u4e00\u4e2a\u7528\u4e8e\u5b89\u88c5DevStack\u7684\u7528\u6237\u3002<\/p>\n<pre class=\"post-pre\"><code>sudo useradd -s \/bin\/bash -d \/opt\/stack -m stack\r\nsudo chmod +x \/opt\/stack\r\necho \"stack ALL=(ALL) NOPASSWD: ALL\" | sudo tee \/etc\/sudoers.d\/stack\r\nsudo -u stack -i\r\n<\/code><\/pre>\n<h3>\u4e0b\u8f7d DevStack<\/h3>\n<p>\u6839\u636e\u9700\u8981\uff0c\u5728Git\u4e0a\u4f7f\u7528\u7279\u5b9a\u5206\u652f\u83b7\u53d6Devstack\u3002<br \/>\n\u6b64\u6b21\u5c06\u4f7f\u75282022\/4\/30\u53d1\u5e03\u7684Yoga\u7248\u3002<\/p>\n<pre class=\"post-pre\"><code>git clone https:\/\/opendev.org\/openstack\/devstack.git\r\ncd devstack\r\ngit checkout stable\/yoga\r\n<\/code><\/pre>\n<h3>\u51c6\u5907 local.conf \u6587\u4ef6<\/h3>\n<p>\u901a\u8fc7local.conf\u6587\u4ef6\u542f\u7528Tacker\u76f8\u5173\u7684Devstack\u63d2\u4ef6\u3002\u672c\u6b21\u4f7f\u7528\u7684\u662f\u9762\u5411Openstack\u548cKubernetes\u4f5c\u4e3aVIM\u7684\u63d2\u4ef6\u3002<\/p>\n<p>\u5728\u53d6\u5f97\u4e4b\u540e\uff0c\u5c06 HOST_IP \u7684\u503c\u66f4\u6539\u4e3a\u81ea\u5df1\u73af\u5883\u4e2d\u7684IP\u3002<br \/>\n\u901a\u8fc7\u5c06\u5176\u66f4\u6539\u4e3a\u53ef\u4ee5\u4ece\u672c\u5730\u4e3b\u673a\u5916\u90e8\u8fde\u63a5\u7684IP\uff0c\u53ef\u4ee5\u5b9e\u73b0\u4ece\u5916\u90e8\u8bbf\u95eeHorizon\u3002<\/p>\n<p>\u5728\u672c\u73af\u5883\u4e2d\uff0c\u6700\u7ec8\u4f7f\u7528\u7684 local.conf \u5982\u4e0b\u6240\u793a\u3002\u6240\u6709\u542f\u7528\u7684\u63d2\u4ef6\u90fd\u4f7f\u7528\u4e86 stable\/yoga \u7248\u672c\u3002\u5728 master \u7248\u672c\u4e2d\u53d1\u751f\u4e86\u540e\u9762\u8981\u63d0\u5230\u7684\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>[[local|localrc]]\r\n############################################################\r\n# Customize the following HOST_IP based on your installation\r\n############################################################\r\nHOST_IP=10.100.2.220\r\n\r\nADMIN_PASSWORD=devstack\r\nMYSQL_PASSWORD=devstack\r\nRABBIT_PASSWORD=devstack\r\nSERVICE_PASSWORD=$ADMIN_PASSWORD\r\nSERVICE_TOKEN=devstack\r\n\r\n############################################################\r\n# Customize the following section based on your installation\r\n############################################################\r\n\r\n# Pip\r\nPIP_USE_MIRRORS=False\r\nUSE_GET_PIP=1\r\n\r\n#OFFLINE=False\r\n#RECLONE=True\r\n\r\n# Logging\r\nLOGFILE=$DEST\/logs\/stack.sh.log\r\nVERBOSE=True\r\nENABLE_DEBUG_LOG_LEVEL=True\r\nENABLE_VERBOSE_LOG_LEVEL=True\r\n\r\n# Neutron ML2 with OpenVSwitch\r\nQ_PLUGIN=ml2\r\nQ_AGENT=ovn\r\nPHYSICAL_NETWORK=mgmtphysnet0\r\n\r\n# Disable security groups\r\nLIBVIRT_FIREWALL_DRIVER=nova.virt.firewall.NoopFirewallDriver\r\n\r\n# Enable neutron, heat, networking-sfc, barbican and mistral\r\nenable_plugin neutron https:\/\/opendev.org\/openstack\/neutron stable\/yoga\r\nenable_plugin heat https:\/\/opendev.org\/openstack\/heat stable\/yoga\r\nenable_plugin networking-sfc https:\/\/opendev.org\/openstack\/networking-sfc stable\/yoga\r\nenable_plugin barbican https:\/\/opendev.org\/openstack\/barbican stable\/yoga\r\nenable_plugin mistral https:\/\/opendev.org\/openstack\/mistral stable\/yoga\r\n\r\n# Ceilometer\r\n#CEILOMETER_PIPELINE_INTERVAL=300\r\nenable_plugin ceilometer https:\/\/opendev.org\/openstack\/ceilometer stable\/yoga\r\nenable_plugin aodh https:\/\/opendev.org\/openstack\/aodh stable\/yoga\r\n\r\n# Blazar\r\nenable_plugin blazar https:\/\/github.com\/openstack\/blazar.git stable\/yoga\r\n\r\n# Tacker\r\nenable_plugin tacker https:\/\/opendev.org\/openstack\/tacker stable\/yoga\r\n\r\nenable_service n-novnc\r\nenable_service n-cauth\r\n\r\ndisable_service tempest\r\n\r\n# Enable kuryr-kubernetes, docker, octavia\r\nKUBERNETES_VIM=True\r\nenable_plugin kuryr-kubernetes https:\/\/opendev.org\/openstack\/kuryr-kubernetes stable\/yoga\r\nenable_plugin octavia https:\/\/opendev.org\/openstack\/octavia stable\/yoga\r\nenable_plugin devstack-plugin-container https:\/\/opendev.org\/openstack\/devstack-plugin-container stable\/yoga\r\n#KURYR_K8S_CLUSTER_IP_RANGE=\"10.0.0.0\/24\"\r\n\r\nenable_service kubernetes-master\r\nenable_service kuryr-kubernetes\r\nenable_service kuryr-daemon\r\n\r\n[[post-config|\/etc\/neutron\/dhcp_agent.ini]]\r\n[DEFAULT]\r\nenable_isolated_metadata = True\r\n\r\n[[post-config|$OCTAVIA_CONF]]\r\n[controller_worker]\r\namp_active_retries=9999\r\n[[post-config|\/etc\/cinder\/cinder.conf]]\r\n[lvmdriver-1]\r\nimage_volume_cache_enabled = False\r\n<\/code><\/pre>\n<h4>\u5173\u4e8elocal.conf<\/h4>\n<p>\u53ef\u4ee5\u4eceTacker\u5b58\u50a8\u5e93\u590d\u5236local.conf\u6587\u4ef6\uff0c\u5e76\u4e14\u6bcf\u79cd\u914d\u7f6e\u7c7b\u578b\u90fd\u6709\u76f8\u5e94\u7684\u793a\u4f8b\u3002<\/p>\n<p>\u57fa\u672c\u7684\u7ec4\u6210\u6709\u4e24\u79cd\u5f62\u5f0f\u3002<\/p>\n<h5>1. \u4e00\u4f53\u673a\u6a21\u5f0f<\/h5>\n<p>\u5b89\u88c5\u5b8c\u6574\u7684Devstack\u73af\u5883\uff0c\u5176\u4e2d\u5305\u542bTacker\u3002<br \/>\n\u8fd9\u4e2a\u6a21\u5f0f\u6709\u4ee5\u4e0b\u4e24\u4e2a\u793a\u4f8b\u3002<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>OpenStack\u4f5c\u4e3aVIM<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>OpenStack\u548cKubernetes\u4f5c\u4e3aVIM<\/ol>\n<p>\u5728\u8fd9\u79cd\u6a21\u5f0f\u4e0b\u7684\u533a\u522b\u662f\uff0cOpenstack \u548c Kubernetes \u4f5c\u4e3a VIM \u90e8\u7f72\u4e86 Octavia \u548c Kuryr-Kubernetes\u3002<\/p>\n<ul class=\"post-ul\">octavia<\/ul>\n<p>\u8fd9\u662f\u4e00\u4e2aOpenStack\u8d1f\u8f7d\u5747\u8861\u670d\u52a1\u3002<br \/>\n\u5b83\u5728\u63a7\u5236\u5668\u8282\u70b9\u4e0a\u8fd0\u884c\u3002<\/p>\n<ul class=\"post-ul\">kuryr-kubernetes<\/ul>\n<p>\u8fd9\u662f\u4e00\u4e2a\u5173\u4e8eOpenStack\u7f51\u7edc\u548cKubernetes\u96c6\u6210\u7684\u9879\u76ee\u3002<br \/>\n\u5176\u76ee\u7684\u662f\u4f7fOpenStack\u4e0a\u7684\u865a\u62df\u673a\uff08VM\uff09\u548cKubernetes\u7684Pod\u53ef\u4ee5\u901a\u8fc7\u540c\u4e00\u4e2aNeutron\u7f51\u7edc\u8fde\u63a5\u3002<\/p>\n<p>\u60a8\u53ef\u4ee5\u4ece Tacker \u5b58\u50a8\u5e93\u4e2d\u590d\u5236\u6837\u672c\u6587\u4ef6\uff0c\u5e76\u786e\u8ba4\u4ee5\u4e0b\u5dee\u5f02\u3002<\/p>\n<pre class=\"post-pre\"><code>$ diff local.conf.example local.conf.kubernetes\r\n37c37,38\r\n&lt; # Enable heat, networking-sfc, barbican and mistral\r\n---\r\n&gt; # Enable neutron, heat, networking-sfc, barbican and mistral\r\n&gt; enable_plugin neutron https:\/\/opendev.org\/openstack\/neutron master\r\n45d45\r\n&lt; CEILOMETER_EVENT_ALARM=True\r\n62a63,73\r\n&gt; # Enable kuryr-kubernetes, docker, octavia\r\n&gt; KUBERNETES_VIM=True\r\n&gt; enable_plugin kuryr-kubernetes https:\/\/opendev.org\/openstack\/kuryr-kubernetes master\r\n&gt; enable_plugin octavia https:\/\/opendev.org\/openstack\/octavia master\r\n&gt; enable_plugin devstack-plugin-container https:\/\/opendev.org\/openstack\/devstack-plugin-container master\r\n&gt; #KURYR_K8S_CLUSTER_IP_RANGE=\"10.0.0.0\/24\"\r\n&gt;\r\n&gt; enable_service kubernetes-master\r\n&gt; enable_service kuryr-kubernetes\r\n&gt; enable_service kuryr-daemon\r\n&gt;\r\n65a77,80\r\n&gt;\r\n&gt; [[post-config|$OCTAVIA_CONF]]\r\n&gt; [controller_worker]\r\n&gt; amp_active_retries=9999\r\n<\/code><\/pre>\n<h5>2. \u72ec\u7acb\u6a21\u5f0f<\/h5>\n<p>\u53ea\u6709\u5305\u542b\u4e86\u4e00\u4e9b\u5fc5\u8981\u7684 OpenStack \u670d\u52a1\u7684 Tacker \u73af\u5883\u624d\u4f1a\u88ab\u5b89\u88c5\u3002<br \/>\nNova\u3001Neutron \u6216\u5176\u4ed6\u91cd\u8981\u7ec4\u4ef6\u4e0d\u4f1a\u88ab\u5305\u62ec\u5728\u6b64\u6a21\u5f0f\u4e2d\u3002<\/p>\n<h3>Devstack \u5b89\u88c5<\/h3>\n<p>\u6267\u884c\u5b89\u88c5\u811a\u672c\u3002<br \/>\n\u8fd9\u4e2a\u811a\u672c\u7684\u6267\u884c\u65f6\u95f4\u53d6\u51b3\u4e8e\u73af\u5883\uff0c\u5927\u7ea6\u9700\u898160\u5230120\u5206\u949f\u3002<br \/>\n\u5728\u6b64\u671f\u95f4\uff0c\u8bf7\u6ce8\u610f\u4e0d\u8981\u53d1\u751f\u8fde\u63a5\u4e2d\u65ad\uff08\u5982ssh\u8fde\u63a5\u65f6\u7684\u65e0\u901a\u4fe1\u65ad\u5f00\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code>.\/stack.sh\r\n<\/code><\/pre>\n<h1>\u53d1\u751f\u7684\u9519\u8bef de<\/h1>\n<p>\u5df2\u603b\u7ed3\u4e86\u5b89\u88c5DevStack\u65f6\u51fa\u73b0\u7684\u9519\u8bef\u3002<\/p>\n<h2>\u4e2d\u5b50\u9519\u8bef<\/h2>\n<p>\u8fd9\u662f\u5728\u6267\u884cstack.sh\u811a\u672c\u65f6\u53d1\u751f\u7684\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>[Call Trace]\r\n.\/stack.sh:1291:start_neutron_service_and_check\r\n\/home\/yoshi\/devstack\/lib\/neutron-legacy:562:test_with_retry\r\n\/home\/yoshi\/devstack\/functions-common:2382:die\r\n[ERROR] \/home\/yoshi\/devstack\/functions-common:2382 Neutron did not start\r\nError on exit\r\n<\/code><\/pre>\n<h3>\u66fe\u7ecf\u5c1d\u8bd5\u8fc7\u7684\u4e8b\u60c5<\/h3>\n<h4>\u6f0f\u6389\u7684\u8bbe\u7f6e\u8865\u5145<\/h4>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\/etc\/hosts \u306b\u5916\u5411\u3051 IP \u306e\u30ed\u30fc\u30ab\u30eb\u540d\u524d\u89e3\u6c7a\u8a2d\u5b9a\u8ffd\u52a0<\/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\">local.conf \u306e HOST_IP \u3092\u5916\u5411\u3051\u306e IP \u306b\u5909\u66f4<\/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\">\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u5b9f\u884c\u3059\u308b\u30e6\u30fc\u30b6\u30fc\u304c\u30d1\u30b9\u30ef\u30fc\u30c9\u306a\u3057\u3067 sudo \u3067\u304d\u308b\u3088\u3046\u306b\u8a2d\u5b9a<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<p>\u7ed3\u679c\uff0c\u6ca1\u6709\u53d1\u751f\u9519\u8bef\u7684\u53d8\u5316\u3002<\/p>\n<h4>\u5806\u6808\u7684\u7528\u6237\u4f7f\u7528<\/h4>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">DevStack \u74b0\u5883\u3092\u521d\u3081\u304b\u3089\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u76f4\u3057<\/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\">stack \u30e6\u30fc\u30b6\u4f5c\u6210\u3057\u3066\u5b9f\u65bd\u3059\u308b (\u53c2\u8003: DevStack)<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<p>\u7ed3\u679c\uff0c\u53d1\u751f\u4e86\u4ee5\u4e0b\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>+inc\/python:pip_install:190                sudo -H LC_ALL=en_US.UTF-8 SETUPTOOLS_USE_DISTUTILS=stdlib http_proxy= https_proxy= no_proxy= PIP_FIND_LINKS= python3.8 -m pip install -c \/opt\/stack\/requirements\/upper-constraints.txt -e \/opt\/stack\/cinder\r\n\/usr\/lib\/python3\/dist-packages\/secretstorage\/dhcrypto.py:15: CryptographyDeprecationWarning: int_from_bytes is deprecated, use int.from_bytes instead\r\n  from cryptography.utils import int_from_bytes\r\n\/usr\/lib\/python3\/dist-packages\/secretstorage\/util.py:19: CryptographyDeprecationWarning: int_from_bytes is deprecated, use int.from_bytes instead\r\n  from cryptography.utils import int_from_bytes\r\nObtaining file:\/\/\/opt\/stack\/cinder\r\nERROR: Exception:\r\nTraceback (most recent call last):\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/req\/req_install.py\", line 443, in check_if_exists\r\n    self.satisfied_by = pkg_resources.get_distribution(str(no_marker))\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 481, in get_distribution\r\n    dist = get_provider(dist)\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 357, in get_provider\r\n    return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0]\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 900, in require\r\n    needed = self.resolve(parse_requirements(requirements))\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 791, in resolve\r\n    raise VersionConflict(dist, req).with_context(dependent_req)\r\npkg_resources.ContextualVersionConflict: (jmespath 1.0.1 (\/usr\/local\/lib\/python3.8\/dist-packages), Requirement.parse('jmespath&lt;1.0.0,&gt;=0.7.1'), {'botocore', 'boto3'})\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/cli\/base_command.py\", line 186, in _main\r\n    status = self.run(options, args)\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/commands\/install.py\", line 357, in run\r\n    resolver.resolve(requirement_set)\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/legacy_resolve.py\", line 177, in resolve\r\n    discovered_reqs.extend(self._resolve_one(requirement_set, req))\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/legacy_resolve.py\", line 333, in _resolve_one\r\n    abstract_dist = self._get_abstract_dist_for(req_to_install)\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/legacy_resolve.py\", line 265, in _get_abstract_dist_for\r\n    return self.preparer.prepare_editable_requirement(req)\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/operations\/prepare.py\", line 560, in prepare_editable_requirement\r\n    req.check_if_exists(self.use_user_site)\r\n  File \"\/usr\/lib\/python3\/dist-packages\/pip\/_internal\/req\/req_install.py\", line 447, in check_if_exists\r\n    existing_dist = pkg_resources.get_distribution(\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 481, in get_distribution\r\n    dist = get_provider(dist)\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 357, in get_provider\r\n    return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0]\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 900, in require\r\n    needed = self.resolve(parse_requirements(requirements))\r\n  File \"\/usr\/share\/python-wheels\/pkg_resources-0.0.0-py2.py3-none-any.whl\/pkg_resources\/__init__.py\", line 791, in resolve\r\n    raise VersionConflict(dist, req).with_context(dependent_req)\r\npkg_resources.ContextualVersionConflict: (jmespath 1.0.1 (\/usr\/local\/lib\/python3.8\/dist-packages), Requirement.parse('jmespath&lt;1.0.0,&gt;=0.7.1'), {'botocore', 'boto3'})\r\n+inc\/python:pip_install:1                  exit_trap\r\n+.\/stack.sh:exit_trap:516                  local r=2\r\n++.\/stack.sh:exit_trap:517                  jobs -p\r\n+.\/stack.sh:exit_trap:517                  jobs=\r\n+.\/stack.sh:exit_trap:520                  [[ -n '' ]]\r\n+.\/stack.sh:exit_trap:526                  '[' -f '' ']'\r\n+.\/stack.sh:exit_trap:531                  kill_spinner\r\n+.\/stack.sh:kill_spinner:426               '[' '!' -z '' ']'\r\n+.\/stack.sh:exit_trap:533                  [[ 2 -ne 0 ]]\r\n+.\/stack.sh:exit_trap:534                  echo 'Error on exit'\r\nError on exit\r\n+.\/stack.sh:exit_trap:536                  type -p generate-subunit\r\n+.\/stack.sh:exit_trap:537                  generate-subunit 1657008105 608 fail\r\n+.\/stack.sh:exit_trap:539                  [[ -z \/opt\/stack\/logs ]]\r\n+.\/stack.sh:exit_trap:542                  \/usr\/bin\/python3.8 \/opt\/stack\/devstack\/tools\/worlddump.py -d \/opt\/stack\/logs\r\novs-vsctl: unix:\/var\/run\/openvswitch\/db.sock: database connection failed (No such file or directory)\r\novs-vsctl: unix:\/var\/run\/openvswitch\/db.sock: database connection failed (No such file or directory)\r\n+.\/stack.sh:exit_trap:551                  exit 2\r\n<\/code><\/pre>\n<h4>\u542f\u52a8ovn\u670d\u52a1<\/h4>\n<pre class=\"post-pre\"><code>ovs-vsctl: unix:\/var\/run\/openvswitch\/db.sock: database connection failed (No such file or directory)\r\novs-vsctl: unix:\/var\/run\/openvswitch\/db.sock: database connection failed (No such file or directory)\r\n<\/code><\/pre>\n<p>\u4ece\u4e0a\u8ff0\u9519\u8bef\u4e2d\u6267\u884c\u4ee5\u4e0b\u64cd\u4f5c\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">ovn \u30b5\u30fc\u30d3\u30b9\u7b49\u8d77\u52d5<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<pre class=\"post-pre\"><code>sudo systemctl start ovn-northd.service\r\nsudo systemctl start ovn-controller.service\r\nsudo systemctl start ovs-vswitchd.service\r\nsudo systemctl start ovsdb-server.service\r\n<\/code><\/pre>\n<p>\u7ed3\u679c\uff0c\u6570\u636e\u5e93\u8fde\u63a5\u5931\u8d25\u7684\u9519\u8bef\u5df2\u7ecf\u6d88\u5931\uff0c\u4f46\u5176\u4ed6\u9519\u8bef\u4ecd\u7136\u5b58\u5728\u3002<\/p>\n<h4>\u66f4\u65b0 apt-get<\/h4>\n<p>\u67e5\u770b\u65e5\u5fd7\u65f6\uff0c\u53d1\u73b0\u4ee5\u4e0b\u8bb0\u5f55\u3002<\/p>\n<pre class=\"post-pre\"><code>ERROR: neutron 20.1.0.dev412 has requirement neutron-lib&gt;=2.21.0, but you'll have neutron-lib 2.20.0 which is incompatible.\r\nERROR: neutron 20.1.0.dev412 has requirement oslo.policy&gt;=3.12.0, but you'll have oslo-policy 3.11.0 which is incompatible.\r\nERROR: neutron 20.1.0.dev412 has requirement ovsdbapp&gt;=1.16.0, but you'll have ovsdbapp 1.15.2 which is incompatible.\r\nInstalling collected packages: neutron\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u6700\u521d\u6ca1\u6709\u66f4\u65b0apt\uff0c\u5bfc\u81f4neutron-lib\uff082.20.0\uff09\u7684\u7248\u672c\u8f83\u65e7\uff0c\u56e0\u6b64\u8981\u6267\u884c\u4ee5\u4e0b\u64cd\u4f5c\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">apt-get update \u3092\u5b9f\u884c<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<p>\u7ed3\u679c\uff0c\u9519\u8bef\u6ca1\u6709\u4efb\u4f55\u53d8\u5316\u3002<br \/>\nneutron-lib \u7684\u7248\u672c\u6ca1\u6709\u81ea\u52a8\u5347\u7ea7\u3002<\/p>\n<h4>\u5c06neutron\u66f4\u6539\u4e3astable\/yoga\u3002<\/h4>\n<p>\u67e5\u770b journalctl \u540e\u53d1\u73b0\u51fa\u73b0\u4e86\u4ee5\u4e0b\u5bfc\u5165\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>$ journalctl -xe -u devstack@q-svc.service --no-pager\r\n\r\n...\r\n\r\nERROR neutron   File \"\/opt\/stack\/neutron\/neutron\/plugins\/ml2\/plugin.py\", line 45, in &lt;module&gt;\r\nERROR neutron     from neutron_lib.api.definitions import port_mac_address_override\r\nERROR neutron ImportError: cannot import name 'port_mac_address_override' from 'neutron_lib.api.definitions' (\/usr\/local\/lib\/python3.8\/dist-packages\/neutron_lib\/api\/definitions\/__init__.py)\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u6700\u8fd1\u5b9e\u65bd\u4e86port_mac_address_override\u4e14\u65e0\u6cd5\u5bfc\u5165\uff0c\u6240\u4ee5\u53d1\u751f\u4e86\u4ee5\u4e0b\u9519\u8bef\uff0c\u6211\u6267\u884c\u4e86\u4e0b\u9762\u7684\u64cd\u4f5c\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">neutron \u306e\u30d5\u30a1\u30a4\u30eb (\/opt\/stack\/neutron) \u3092 stable\/yoga \u306b checkout \u3092\u5b9f\u65bd<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<p>\u7ed3\u679c\uff0c\u53d1\u751f\u4e86\u4ee5\u4e0b\u4e24\u4e2a\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>AttributeError: module 'neutron.common.config' has no attribute 'register_common_config_options'\r\n\r\novs-vsctl: unix:\/var\/run\/openvswitch\/db.sock: database connection failed (No such file or directory)\r\n<\/code><\/pre>\n<h4>\u5c06\u73af\u5883\u6062\u590d\u5230\u6267\u884c stack.sh \u4e4b\u524d\u5e76\u6267\u884c\u3002<\/h4>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u4e00\u5ea6\u304d\u308c\u3044\u306a\u74b0\u5883\u306b\u3057\u3001\u4eca\u307e\u3067\u306e\u5bfe\u7b56\u3092\u3059\u3079\u3066\u5b9f\u65bd<\/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\">neutron \u304c stable\/yoga \u3092\u5229\u7528\u3059\u308b\u3088\u3046\u306b\u6307\u5b9a\u3059\u308b\u305f\u3081\u306b\u4e0b\u8a18\u306e\u3088\u3046\u306b local.conf \u5909\u66f4<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6\u3001stack.sh \u30b9\u30af\u30ea\u30d7\u30c8\u5b9f\u884c<\/ul>\n<pre class=\"post-pre\"><code>$ vim local.conf \r\n\r\n\u30fb\u30fb\u30fb\r\n\r\n# Enable neutron, heat, networking-sfc, barbican and mistral\r\nenable_plugin neutron https:\/\/opendev.org\/openstack\/neutron master\r\n--\r\nenable_plugin neutron https:\/\/opendev.org\/openstack\/neutron stable\/yoga\u3000\u2190\u306b\u5909\u66f4\r\n<\/code><\/pre>\n<p>\u7ed3\u679c\uff0c\u53d1\u751f\u4e86\u4ee5\u4e0b\u9519\u8bef\u3002<\/p>\n<pre class=\"post-pre\"><code>\/usr\/lib\/python3\/dist-packages\/secretstorage\/util.py:19: CryptographyDeprecationWarning: int_from_bytes is deprecated, use int.from_bytes instead\r\n  from cryptography.utils import int_from_bytes\r\nTraceback (most recent call last):\r\n  File \"\/usr\/local\/bin\/neutron-db-manage\", line 10, in &lt;module&gt;\r\n    sys.exit(main())\r\n  File \"\/opt\/stack\/neutron\/neutron\/db\/migration\/cli.py\", line 661, in main\r\n    return_val |= bool(CONF.command.func(config, CONF.command.name))\r\n  File \"\/opt\/stack\/neutron\/neutron\/db\/migration\/cli.py\", line 183, in do_upgrade\r\n    run_sanity_checks(config, revision)\r\n  File \"\/opt\/stack\/neutron\/neutron\/db\/migration\/cli.py\", line 645, in run_sanity_checks\r\n    script_dir.run_env()\r\n  File \"\/usr\/local\/lib\/python3.8\/dist-packages\/alembic\/script\/base.py\", line 563, in run_env\r\n    util.load_python_file(self.dir, \"env.py\")\r\n  File \"\/usr\/local\/lib\/python3.8\/dist-packages\/alembic\/util\/pyfiles.py\", line 92, in load_python_file\r\n    module = load_module_py(module_id, path)\r\n  File \"\/usr\/local\/lib\/python3.8\/dist-packages\/alembic\/util\/pyfiles.py\", line 108, in load_module_py\r\n    spec.loader.exec_module(module)  # type: ignore\r\n  File \"&lt;frozen importlib._bootstrap_external&gt;\", line 848, in exec_module\r\n  File \"&lt;frozen importlib._bootstrap&gt;\", line 219, in _call_with_frames_removed\r\n  File \"\/opt\/stack\/networking-sfc\/networking_sfc\/db\/migration\/alembic_migrations\/env.py\", line 25, in &lt;module&gt;\r\n    from networking_sfc.db.migration.models import head  # noqa\r\n  File \"\/opt\/stack\/networking-sfc\/networking_sfc\/db\/migration\/models\/head.py\", line 17, in &lt;module&gt;\r\n    from networking_sfc.db import flowclassifier_db  # noqa\r\n  File \"\/opt\/stack\/networking-sfc\/networking_sfc\/db\/flowclassifier_db.py\", line 34, in &lt;module&gt;\r\n    from networking_sfc.extensions import flowclassifier as fc_ext\r\n  File \"\/opt\/stack\/networking-sfc\/networking_sfc\/extensions\/flowclassifier.py\", line 34, in &lt;module&gt;\r\n    common_config.register_common_config_options()\r\nAttributeError: module 'neutron.common.config' has no attribute 'register_common_config_options'\r\n<\/code><\/pre>\n<p>\u6211\u5f97\u5230\u4e86\u524d\u8f88\u7684\u4ee5\u4e0b\u53cd\u9988\u3002<\/p>\n<p>\u7f51\u7edc\u670d\u52a1\u51fd\u6570\uff08networking-sfc\uff09\u5728\u8c03\u7528neutron\u5e93\u7684\u8fc7\u7a0b\u4e2d\u51fa\u73b0\u4e86\u5c5e\u6027\u9519\u8bef\u3002\u53ef\u80fd\u662f\u56e0\u4e3anetworking-sfc\u5904\u4e8emaster\u5206\u652f\uff0c\u800cneutron\u5904\u4e8estable\/yoga\u5206\u652f\uff0c\u6240\u4ee5\u5bfc\u81f4\u4e86\u4e0d\u4e00\u81f4\u3002\u5efa\u8bae\u5c06local.conf\u4e2d\u7684\u5176\u4ed6\u90e8\u5206\u4e5f\u4fee\u6539\u4e3a\u5f15\u7528stable\/yoga\u5206\u652f\uff0c\u53ef\u80fd\u4f1a\u66f4\u597d\u3002<\/p>\n<h4>\u5c06\u672c\u5730\u914d\u7f6e\u6587\u4ef6 local.conf \u4e2d\u7684\u6240\u6709\u5206\u652f\u90fd\u66f4\u6539\u4e3a stable\/yoga\u3002<\/h4>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u524d\u56de\u306e stack.sh \u3092\u5b9f\u884c\u3059\u308b\u524d\u306e\u72b6\u614b\u306b\u623b\u3059<\/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\">\u4e0b\u8a18\u306e local.conf \u306b\u5909\u66f4<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u518d\u5ea6 stack.sh \u5b9f\u884c<\/ul>\n<pre class=\"post-pre\"><code>$ cat local.conf\r\n[[local|localrc]]\r\n############################################################\r\n# Customize the following HOST_IP based on your installation\r\n############################################################\r\nHOST_IP=10.100.2.220\r\n\r\nADMIN_PASSWORD=devstack\r\nMYSQL_PASSWORD=devstack\r\nRABBIT_PASSWORD=devstack\r\nSERVICE_PASSWORD=$ADMIN_PASSWORD\r\nSERVICE_TOKEN=devstack\r\n\r\n############################################################\r\n# Customize the following section based on your installation\r\n############################################################\r\n\r\n# Pip\r\nPIP_USE_MIRRORS=False\r\nUSE_GET_PIP=1\r\n\r\n#OFFLINE=False\r\n#RECLONE=True\r\n\r\n# Logging\r\nLOGFILE=$DEST\/logs\/stack.sh.log\r\nVERBOSE=True\r\nENABLE_DEBUG_LOG_LEVEL=True\r\nENABLE_VERBOSE_LOG_LEVEL=True\r\n\r\n# Neutron ML2 with OpenVSwitch\r\nQ_PLUGIN=ml2\r\nQ_AGENT=ovn\r\nPHYSICAL_NETWORK=mgmtphysnet0\r\n\r\n# Disable security groups\r\nLIBVIRT_FIREWALL_DRIVER=nova.virt.firewall.NoopFirewallDriver\r\n\r\n# Enable neutron, heat, networking-sfc, barbican and mistral\r\nenable_plugin neutron https:\/\/opendev.org\/openstack\/neutron stable\/yoga\r\nenable_plugin heat https:\/\/opendev.org\/openstack\/heat stable\/yoga\r\nenable_plugin networking-sfc https:\/\/opendev.org\/openstack\/networking-sfc stable\/yoga\r\nenable_plugin barbican https:\/\/opendev.org\/openstack\/barbican stable\/yoga\r\nenable_plugin mistral https:\/\/opendev.org\/openstack\/mistral stable\/yoga\r\n\r\n# Ceilometer\r\n#CEILOMETER_PIPELINE_INTERVAL=300\r\nenable_plugin ceilometer https:\/\/opendev.org\/openstack\/ceilometer stable\/yoga\r\nenable_plugin aodh https:\/\/opendev.org\/openstack\/aodh stable\/yoga\r\n\r\n# Blazar\r\nenable_plugin blazar https:\/\/github.com\/openstack\/blazar.git stable\/yoga\r\n\r\n# Tacker\r\nenable_plugin tacker https:\/\/opendev.org\/openstack\/tacker stable\/yoga\r\n\r\nenable_service n-novnc\r\nenable_service n-cauth\r\n\r\ndisable_service tempest\r\n\r\n# Enable kuryr-kubernetes, docker, octavia\r\nKUBERNETES_VIM=True\r\nenable_plugin kuryr-kubernetes https:\/\/opendev.org\/openstack\/kuryr-kubernetes stable\/yoga\r\nenable_plugin octavia https:\/\/opendev.org\/openstack\/octavia stable\/yoga\r\nenable_plugin devstack-plugin-container https:\/\/opendev.org\/openstack\/devstack-plugin-container stable\/yoga\r\n#KURYR_K8S_CLUSTER_IP_RANGE=\"10.0.0.0\/24\"\r\n\r\nenable_service kubernetes-master\r\nenable_service kuryr-kubernetes\r\nenable_service kuryr-daemon\r\n\r\n[[post-config|\/etc\/neutron\/dhcp_agent.ini]]\r\n[DEFAULT]\r\nenable_isolated_metadata = True\r\n\r\n[[post-config|$OCTAVIA_CONF]]\r\n[controller_worker]\r\namp_active_retries=9999\r\n[[post-config|\/etc\/cinder\/cinder.conf]]\r\n[lvmdriver-1]\r\nimage_volume_cache_enabled = False\r\n<\/code><\/pre>\n<p>\u6700\u7ec8\uff0c\u5b89\u88c5\u5df2\u5b8c\u6210\u3002\u60a8\u4e5f\u53ef\u4ee5\u5728http:\/\/10.100.2.220\/dashboard \u4e0a\u67e5\u770bHorizon\u4eea\u8868\u677f\u3002<\/p>\n<pre class=\"post-pre\"><code>$ .\/stack.sh\r\n\r\n\u30fb\u30fb\u30fb\r\n\r\n=========================\r\nDevStack Component Timing\r\n(times are in seconds)\r\n=========================\r\nwait_for_service      22\r\npip_install          569\r\napt-get              908\r\nrun_process           71\r\ndbsync                32\r\ngit_timed            1112\r\napt-get-update       10\r\ntest_with_retry        8\r\nasync_wait           356\r\nosc 1011\r\n-------------------------\r\nUnaccounted time   2453\r\n=========================\r\nTotal runtime        6552\r\n\r\n=================\r\nAsync summary\r\n=================\r\nTime spent in the background minus waits: 690 sec\r\nElapsed time: 6552 sec \r\nTime if we did everything serially: 7242 sec\r\nSpeedup:  1.10531\r\n\r\n\r\nThis is your host IP address: 10.100.2.220\r\nThis is your host IPv6 address: ::1\r\nHorizon is now available at http:\/\/10.100.2.220\/dashboard  \r\nKeystone is serving at http:\/\/10.100.2.220\/identity\/  \r\nThe default users are: admin and demo\r\nThe password: devstack\r\n\r\nServices are running under systemd unit files.\r\nFor more information see:\r\nhttps:\/\/docs.openstack.org\/devstack\/latest\/systemd.html\r\n\r\nDevStack Version: yoga\r\nChange: 6f545e2567166ed9790601ccb589307df688d40d Allow to skip stop of ovn services 2022-05-31 07:31:08 +0000                     \r\nOS Version: Ubuntu 20.04 focal\r\n<\/code><\/pre>\n<h2>\u5728\u514b\u9686 ceilometer \u65f6\uff0cgit \u8c03\u7528\u5931\u8d25\u3002<\/h2>\n<pre class=\"post-pre\"><code>Cloning into '\/opt\/stack\/ceilometer'...\r\nerror: RPC failed; curl 56 GnuTLS recv error (-9): Error decoding the received TLS packet.\r\nfatal: the remote end hung up unexpectedly\r\nfatal: early EOF\r\nfatal: index-pack failed\r\n+ESC[38;5;242mfunctions-common:git_timed:725           ESC[m^O [[ 128 -ne 124 ]]\r\n+ESC[38;5;242mfunctions-common:git_timed:726           ESC[m^O die 726 'git call failed: [git clone' https:\/\/opendev.org\/openstack\/ceilometer \/opt\/stack\/ceilometer --branch 'master]'\r\n+ESC[38;5;242mfunctions-common:die:264                 ESC[m^O local exitcode=0\r\n[Call Trace]\r\n.\/stack.sh:590:fetch_plugins\r\n\/opt\/stack\/devstack\/functions-common:1793:git_clone_by_name\r\n\/opt\/stack\/devstack\/functions-common:702:git_clone\r\n\/opt\/stack\/devstack\/functions-common:650:git_timed\r\n\/opt\/stack\/devstack\/functions-common:726:die\r\n[ERROR] \/opt\/stack\/devstack\/functions-common:726 git call failed: [git clone https:\/\/opendev.org\/openstack\/ceilometer \/opt\/stack\/ceilometer --branch master]\r\nError on exit\r\n<\/code><\/pre>\n<p>\u7531\u4e8egit clone\u64cd\u4f5c\u4ec5\u6682\u65f6\u5931\u8d25\uff0c\u6211\u4eec\u901a\u8fc7\u518d\u6b21\u6267\u884c\u8be5\u64cd\u4f5c\u89e3\u51b3\u4e86\u95ee\u9898\u3002<\/p>\n<h2>Kubernetes \u542f\u52a8\u5931\u8d25<\/h2>\n<p>\u8fd9\u4e2a\u9519\u8bef\u4e0e\u901a\u8fc7 Devstack \u5b89\u88c5\u7684\u6b65\u9aa4\u6ca1\u6709\u76f4\u63a5\u5173\u7cfb\uff0c\u5b83\u662f\u7531\u6211\u81ea\u5df1\u5b9e\u9a8c\u65f6\u53d1\u751f\u7684\u3002<\/p>\n<p>\u5728\u8bbe\u7f6e local.conf \u7684\u8fc7\u7a0b\u4e2d\uff0cKubernetes \u5b8c\u5168\u65e0\u6cd5\u8fd0\u884c\u3002<br \/>\n\u5728\u6267\u884c stack.sh \u811a\u672c\u540e\uff0c\u751a\u81f3\u6ca1\u6709 kubelet \u547d\u4ee4\u7b49\u3002<\/p>\n<p>\u6211\u4f7f\u7528\u8fd9\u4e2a local.conf \u914d\u7f6e\u6587\u4ef6\u5c1d\u8bd5\u4e0d\u5b89\u88c5 kuryr-kubernetes\uff0c\u800c\u662f\u5b89\u88c5 Calico \u4f5c\u4e3a CNI\uff0c\u5e76\u786e\u4fdd\u5728 OpenStack \u4e0a\u7684\u865a\u62df\u673a\u548c Kubernetes \u7684 Pod \u4e0d\u5728\u540c\u4e00\u4e2a Neutron \u7f51\u7edc\u4e2d\u8fde\u63a5\u3002<\/p>\n<pre class=\"post-pre\"><code>$ cat local.conf\r\n[[local|localrc]]\r\n############################################################\r\n# Customize the following HOST_IP based on your installation\r\n############################################################\r\nHOST_IP=10.100.2.211\r\n\r\n\u30fb\u30fb\u30fb\r\n\r\n# Enable kuryr-kubernetes, docker, octavia\r\nKUBERNETES_VIM=True\r\n#enable_plugin kuryr-kubernetes https:\/\/opendev.org\/openstack\/kuryr-kubernetes stable\/yoga\r\nenable_plugin calico https:\/\/git.openstack.org\/openstack\/networking-calico\r\nenable_plugin octavia https:\/\/opendev.org\/openstack\/octavia stable\/yoga\r\nenable_plugin devstack-plugin-container https:\/\/opendev.org\/openstack\/devstack-plugin-container stable\/yoga\r\n#KURYR_K8S_CLUSTER_IP_RANGE=\"10.0.0.0\/24\"\r\n\r\nenable_service kubernetes-master\r\n#enable_service kuryr-kubernetes\r\n#enable_service kuryr-daemon\r\n\r\n\u30fb\u30fb\u30fb\r\n<\/code><\/pre>\n<p>\u5728\u5c1d\u8bd5\u8fd9\u4e2a\u6b65\u9aa4\u4e4b\u524d\uff0c\u6211\u4ee5\u4e3aKubernetes\u76f8\u5173\u7684\u5185\u5bb9\u9700\u8981\u5728kubernetes-master\u4e2d\u8bbf\u95ee\uff0c\u5e76\u4e14kuryr-kubernetes\u4f1a\u5c06Kubernetes\u7f51\u7edc\u8fde\u63a5\u5230OpenStack\u3002<\/p>\n<p>DevStack\u7684\u6839\u76ee\u5f55\u901a\u5e38\u5305\u542b\u4e0eDevStack\u76f8\u5173\u7684\u5185\u5bb9\uff0c\u56e0\u6b64\u68c0\u67e5DevStack\u7684\u6839\u76ee\u5f55\u53ef\u4ee5\u786e\u8ba4\u6709neutron\u548ckuryr-kubernetes\u7b49\u5185\u5bb9\u3002<br \/>\n\u7136\u800c\uff0c\u53ef\u4ee5\u770b\u5230\u4e0d\u5b58\u5728kubernetes-master\u7b49\u5185\u5bb9\uff0c\u53ea\u6709kuryr-kubernetes\u4e0eKubernetes\u76f8\u5173\u7684\u9879\u76ee\u3002<\/p>\n<p>\u5982\u679c\u4f7f\u7528`grep`\u547d\u4ee4\u5728kuryr-kubernetes\u5185\u641c\u7d22\uff0c\u4f1a\u51fa\u73b0&#8221;kubeadm&#8221;\u548c&#8221;kubernetes-master&#8221;\u7684\u6587\u672c\u5339\u914d\u3002\u56e0\u6b64\uff0c\u5982\u679ckuryr-kubernetes\u4e0d\u5b58\u5728\uff0cKubernetes\u4f3c\u4e4e\u65e0\u6cd5\u6b63\u5e38\u5de5\u4f5c\u3002<\/p>\n<pre class=\"post-pre\"><code>grep -e \"kubernetes-master\" -rn .\/kuryr-kubernetes\/\r\ngrep -e \"kubeadm\" -rn .\/kuryr-kubernetes\/\r\n<\/code><\/pre>\n<p>\u5728\u7ed3\u8bba\u4e2d\uff0c\u6211\u4eec\u5f97\u51fa\u4e86\u4e00\u4e2a\u7ed3\u8bba\uff1a\u5982\u679c\u6ca1\u6709\u542f\u7528Kuryr-Kubernetes\uff0cKubernetes\u5c06\u65e0\u6cd5\u5728Devstack\u4e0a\u8fd0\u884c\u3002<\/p>\n<h1>\u603b\u7ed3<\/h1>\n<p>\u5f88\u591a\u9519\u8bef\u53d1\u751f\uff0c\u4f46Tacker\u5df2\u7ecf\u5728DevStack\u73af\u5883\u4e2d\u6210\u529f\u8fd0\u884c\u8d77\u6765\u4e86\u3002<br \/>\n\u4e0b\u6b21\u6211\u4eec\u5c06\u4f7f\u7528TOSCA\u5728VM\u4e0a\u90e8\u7f72NFV\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u76ee\u5f55 1. \u9996\u5148 2. \u73af\u5883 3. \u5b89\u88c5\u6b65\u9aa4 4. \u9047\u5230\u7684\u9519\u8bef 5. \u603b\u7ed3 URL\u7684\u53c2\u8003 Install vi [&hellip;]<\/p>\n","protected":false},"author":4,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-36128","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>\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b - 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\/\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728devstack\u4e0a\u4f7f\u7528tacker\u7684\u6545\u4e8b\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b\" \/>\n<meta property=\"og:description\" content=\"\u76ee\u5f55 1. \u9996\u5148 2. \u73af\u5883 3. \u5b89\u88c5\u6b65\u9aa4 4. \u9047\u5230\u7684\u9519\u8bef 5. \u603b\u7ed3 URL\u7684\u53c2\u8003 Install vi [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728devstack\u4e0a\u4f7f\u7528tacker\u7684\u6545\u4e8b\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-06-04T23:45:11+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T07:46:20+00:00\" \/>\n<meta name=\"author\" content=\"\u79d1, \u96c5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u79d1, \u96c5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"13 \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%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/\",\"name\":\"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-06-04T23:45:11+00:00\",\"dateModified\":\"2024-04-30T07:46:20+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b\"}]},{\"@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\/41e222757cdd2a3365361328bd79970a\",\"name\":\"\u79d1, \u96c5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"caption\":\"\u79d1, \u96c5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b - 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\/\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728devstack\u4e0a\u4f7f\u7528tacker\u7684\u6545\u4e8b\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b","og_description":"\u76ee\u5f55 1. \u9996\u5148 2. \u73af\u5883 3. \u5b89\u88c5\u6b65\u9aa4 4. \u9047\u5230\u7684\u9519\u8bef 5. \u603b\u7ed3 URL\u7684\u53c2\u8003 Install vi [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728devstack\u4e0a\u4f7f\u7528tacker\u7684\u6545\u4e8b\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-06-04T23:45:11+00:00","article_modified_time":"2024-04-30T07:46:20+00:00","author":"\u79d1, \u96c5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u79d1, \u96c5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"13 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/","name":"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-06-04T23:45:11+00:00","dateModified":"2024-04-30T07:46:20+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4e00\u4f4d\u65b0\u52a0\u5165\u7684\u4eba\u8bd5\u56fe\u5728DevStack\u4e0a\u4f7f\u7528Tacker\u7684\u6545\u4e8b"}]},{"@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\/41e222757cdd2a3365361328bd79970a","name":"\u79d1, \u96c5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","caption":"\u79d1, \u96c5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%b8%80%e4%bd%8d%e6%96%b0%e5%8a%a0%e5%85%a5%e7%9a%84%e4%ba%ba%e8%af%95%e5%9b%be%e5%9c%a8devstack%e4%b8%8a%e4%bd%bf%e7%94%a8tacker%e7%9a%84%e6%95%85%e4%ba%8b\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/36128","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\/4"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=36128"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/36128\/revisions"}],"predecessor-version":[{"id":92811,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/36128\/revisions\/92811"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=36128"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=36128"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=36128"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}