私有雲版本 4.17.09 版本
安裝總覽
在節點上安裝 apigee-setup
公用程式之後,請使用該公用程式在節點上安裝一或多個 BaaS 元件。
apigee-setup
公用程式的形式如下:
sudo /opt/apigee/apigee-setup/bin/setup.sh -p component -f configFile
將設定檔傳送至包含安裝相關資訊的 apigee-setup
公用程式。如果設定檔缺少任何必要資訊,apigee-setup
公用程式會要求您在指令列中輸入。
唯一的規定是設定檔必須可供「Apigee」使用者存取或讀取。
舉例來說,使用下列指令安裝 API BaaS 堆疊:
sudo /opt/apigee/apigee-setup/bin/setup.sh -p b -f myConfig
指定要安裝的元件
Apigee setup.sh
公用程式支援多種 API 安裝 API 標記元件。下方的操作說明採用獨立選項 (c、e、b 和 p),但您可以根據節點設定使用不同的選項:
選項 |
Description |
---|---|
e |
僅安裝 ElasticSearch。 |
b |
僅安裝 API BaaS Stack,這也會安裝 Tomcat。 |
p |
僅安裝 API BaaS 入口網站,其中也會安裝可供做為網路伺服器的 Nginx 路由器。 |
c |
僅安裝 Cassandra。 |
eb |
在節點上安裝 ElasticSearch、API BaaS Stack 和 Tomcat。 |
羊毛 |
安裝 ElasticSearch、API BaaS 入口網站、API BaaS Stack 和 Tomcat,但不安裝 Cassandra。傳送門是輕量的其他資源。 |
阿根廷 |
在單一節點 (Cassandra、Elasticsearch、API BaaS Stack、API BaaS 入口網站、Tomcat) 上安裝所有 API BaaS 元件。這個選項只能用於開發及測試,不適用於實際工作環境。 |
建立設定檔
設定檔包含安裝 API BaaS 所需的所有資訊。您通常可以使用同一個設定檔在 BaaS 安裝作業中安裝所有元件。
下文將介紹每個安裝拓撲,並提供該拓撲的範例設定檔。如需設定檔的完整參考資料,請參閱「BaaS 設定檔參考資料」。
在單一節點上安裝 API BaaS
以下範例顯示在單一節點上安裝 API BaaS 的設定檔。視需要編輯這項設定。如需設定檔的完整參考資料,請參閱「BaaS 設定檔參考資料」。
IP1=192.168.56.101 # IP address of single node # Must resolve to IP address or DNS name of host - not to 127.0.0.1 or localhost. HOSTIP=$(hostname -i) # Define the API BaaS administrator account. AS_ADMIN="superuser" # User name - default is "superuser". AS_ADMIN_EMAIL=stackAdmin@email.com AS_PASSWD=stackAdminPWord # Because you are installing Cassandra, # specify Cassandra data center and rack suffix. # Must use IP addresses for CASS_HOSTS, not DNS names. CASS_HOSTS="$IP1:1,1" # Specify the Cassandra region. REGION=dc-1 # Cassandra uname/pword. # Even if Cassandra authentication is disabled, # you must still pass values for these properties. CASS_USERNAME=cassandra # Default value CASS_PASSWORD=cassandra # Default value # Specify Cassandra data center name. BAAS_CASS_LOCALDC=dc-1 # For a single data center, specify the same value as BAAS_CASS_LOCALDC. BAAS_CASS_DC_LIST=dc-1 # Replication is in the form "dataCenterName:#CassandraNodes". # For dc-1 with one Cassandra node, it is dc-1:1. BAAS_CASS_REPLICATION=dc-1:1 # Defines the initial contact points for members of the BaaS cluster. # For a single node install, specify the IP address of the node. BAAS_CLUSTER_SEEDS="dc-1:$IP1" # Single ElasticSearch IP. ES_HOSTS="$IP1" # API BaaS Stack information. # Default cluster name is "apigee_baas" BAAS_USERGRID_CLUSTERNAME="apigee_baas" # IP/DNS and port 8080 of a single Stack node. BAAS_USERGRID_URL="http://$IP1:8080" # URL and port of the BaaS Portal node. BAAS_PORTAL_URL="http://$IP1:9000" # Portal port. Default value is 9000. BAAS_PORTAL_LISTEN_PORT=9000 # SMTP information. BaaS requires an SMTP server. SMTPHOST=smtp.gmail.com SMTPPORT=465 SMTPUSER=your@email.com SMTPPASSWORD=yourEmailPassword SMTPSSL=y SMTPMAILFROM="My Company <myco@company.com>"
如要在專屬節點上安裝 API BaaS,請按照下列步驟操作:
- 透過網際網路或非網際網路程序,在節點上安裝 Edge
apigee-setup
公用程式。詳情請參閱「安裝 Edge Apigee 設定公用程式」。 - 在命令提示字元中,執行設定指令碼:
/opt/apigee/apigee-setup/bin/setup.sh -p asa -f configFile
「-p asa」選項會指定在單一節點上安裝所有 API BaaS 元件 (Cassandra、Elasticsearch、API BaaS Stack、API BaaS 入口網站、Tomcat)。
設定檔必須由「Apigee」使用者存取或讀取。
- 由於您在獨立節點上安裝 ElasticSearch,因此請調整預設記憶體選項,將 ElasticSearch 的記憶體容量從 4 GB 增加至 6 GB:
- 在編輯器中開啟
/opt/apigee/customer/application/elasticsearch.properties
。如果這個檔案不存在,請建立這個檔案。 - 將
setenv_elasticsearch_max_mem_size
屬性設為 6g (預設為 4g):
setenv_elasticsearch_max_mem_size=6g
- 儲存檔案。
- 執行下列指令:
/opt/apigee/apigee-service/bin/apigee-service apigee-elasticsearch restart
- 在編輯器中開啟
- 按照下方「加入新機構」一節的說明,將機構加入。
設定成功完成節點上的設定。
在 7 或 10 個節點上安裝 API BaaS
安裝 API 70 或 10 個節點版本的 API BaaS 的程序非常相似。唯一的差別在於:
- 安裝 10 個節點,在「獨立」節點中安裝三個 ElasticSearch 元件和三個 API BaaS 堆疊元件,總共六個節點。由於 ElasticSearch 需要大量磁碟 I/O 和記憶體,因此我們建議以最佳效能為目標。
- 安裝 7 個節點後,在「同一個」節點中安裝三個 ElasticSearch 元件和三個 API BaaS 堆疊元件,總共三個節點。
針對 API BaaS 的 7 及 10 節點版本,您必須連線至 Cassandra 叢集。如果您已安裝 Edge,可以連線至其 Cassandra 叢集,也就是說,在安裝 API BaaS 時,不需要安裝 Cassandra。
以下是 10 個節點 API BaaS 安裝的靜音設定檔範例。如果您是在相同節點上安裝 ElasticSearch 和 API BaaS Stack 元件,請編輯該檔案,以便:
- IP1 和 IP4 設為相同的 IP 位址
- IP2 和 IP5 設為相同 IP 位址
- IP3 和 IP6 已設為相同的 IP 位址
視需要編輯這項設定。如需設定檔的完整參考資料,請參閱BaaS 設定檔參考資料。
# Specify IP address or DNS name of node. IP1=192.168.1.1 # ElasticSearch IP2=192.168.1.2 # ElasticSearch IP3=192.168.1.3 # ElasticSearch IP4=192.168.1.4 # API BaaS Stack IP5=192.168.1.5 # API BaaS Stack IP6=192.168.1.6 # API BaaS Stack IP7=192.168.1.7 # API BaaS Portal IP8=192.168.1.8 # Cassandra (shared with Edge or standalone) IP9=192.168.1.9 # Cassandra (shared with Edge or standalone) IP10=192.168.1.10 # Cassandra (shared with Edge or standalone) # Must resolve to IP address or DNS name of host - not to 127.0.0.1 or localhost. HOSTIP=$(hostname -i) # Define the API BaaS administrator account. AS_ADMIN="superuser" # User name - default is "superuser". AS_ADMIN_EMAIL=stackAdmin@email.com AS_PASSWD=stackAdminPWord # Only if you are installing Cassandra. # Specify Cassandra data center and rack suffix. # Must use IP addresses for CASS_HOSTS, not DNS names. # CASS_HOSTS="$IP8:1,1 $IP9:1,1 $IP10:1,1" # If connecting to existing Cassandra nodes, # specify Cassandra IPs. # Must use IP addresses for CASS_HOSTS, not DNS names. CASS_HOSTS="$IP8 $IP9 $IP10" # Specify the Cassandra region. REGION=dc-1 # Cassandra uname/pword. # Even if Cassandra authentication is disabled, # you must still pass values for these properties. CASS_USERNAME=cassandra # Default value CASS_PASSWORD=cassandra # Default value # Specify BaaS Cassandra connection information. # Specify the data center name. BAAS_CASS_LOCALDC=dc-1 # Default is dc-1. # For a single data center, specify the same value as BAAS_CASS_LOCALDC. BAAS_CASS_DC_LIST=dc-1 # Replication is in the form "dataCenterName:#CassandraNodes". # For example, for dc-1 with three Cassandra nodes, it is dc-1:3. BAAS_CASS_REPLICATION=dc-1:3 # Defines the initial contact points for members of the BaaS cluster. # Specify the IP address of no more than two Stack nodes. BAAS_CLUSTER_SEEDS="dc-1:$IP4,dc-1:$IP5" # ElasticSearch IPs or DNS names, separated by spaces. ES_HOSTS="$IP1 $IP2 $IP3" # API BaaS Stack information. # Default cluster name is "apigee_baas" BAAS_USERGRID_CLUSTERNAME="apigee_baas" # URL and port of the load balancer for the API BaaS Stack nodes, # or IP/DNS and port 8080 of a single Stack node with no load balancer. BAAS_USERGRID_URL=http://myloadbalancer:8443 # API BaaS Portal information. # URL and port number of load balancer, if there is one in front of the Portal, # or the URL and port of the Portal node. BAAS_PORTAL_URL="http://$IP7:9000" # Portal port. Default value is 9000. BAAS_PORTAL_LISTEN_PORT=9000 # SMTP information. BaaS requires an SMTP server. SMTPHOST=smtp.gmail.com SMTPPORT=465 SMTPUSER=your@email.com SMTPPASSWORD=yourEmailPassword SMTPSSL=y SMTPMAILFROM="My Company <myco@company.com>"
選用 - 安裝 Cassandra:機器 8、9 和 10
您可以將 API BaaS 連結至 Edge 使用的相同 Cassandra 叢集。如果您尚未安裝 Edge,可以選擇安裝 Cassandra 供 API BaaS 使用。
Cassandra 叢集可以使用驗證功能,也可以停用 Cassandra 驗證。詳情請參閱「啟用 Cassandra 驗證」。
- 透過網際網路或非網際網路程序,在節點上安裝 Edge
apigee-setup
公用程式。詳情請參閱「安裝 Edge apigee-setup 公用程式」。 - 在命令提示字元中,執行設定指令碼:
/opt/apigee/apigee-setup/bin/setup.sh -p c -f configFile
「-p c」選項會指定安裝 Cassandra。
設定檔必須由「Apigee」使用者存取或讀取。
設定成功在節點上完成資料儲存庫設定。
請注意,根據預設,Cassandra 會啟用 JMX。JMX 遠端遠端存取 Cassandra 不需要密碼。您可以設定 Cassandra 以使用 JMX 的驗證。詳情請參閱「如何監控」。
設定 Cassandra Cron 工作
如果必須安裝 Cassandra,請設定 Cron 工作,並使用 nodetool
來清除每個 Cassandra 節點上的鎖定鎖定。
如果您有多個 Cassandra 節點,請將每個伺服器上的 Cron 工作偏移五分鐘,以免所有節點同時清除。
Cron 工作必須執行以下指令:
/opt/apigee/apigee-cassandra/bin/nodetool -h IP_address flush Apigee_Baas_Locks
其中 IP_address 是 Cassandra 節點的 IP 位址。
安裝 ElasticSearch:機器 1、2 和 3
如何在其節點上安裝 ElasticSearch:
- 透過網際網路或非網際網路程序,在節點上安裝 Edge Apigee-setup 公用程式。詳情請參閱「安裝 Edge Apigee 設定公用程式」。
- 在命令提示字元中,執行設定指令碼:
/opt/apigee/apigee-setup/bin/setup.sh -p e -f configFile
The "-p e" option specifies to install ElasticSearch. The configuration file must be accessible or readable by the "apigee" user.
- (Optional) If you install ElasticSearch on a standalone node, meaning it is not installed
with API BaaS Stack, then adjust the default memory option to increase the memory allocated for
ElasticSearch from 4GB to 6GB:
- Open
/opt/apigee/customer/application/elasticsearch.properties
in an editor. If this file does not exist, create it. - Set the
setenv_elasticsearch_max_mem_size
property to 6g (the default is 4g):setenv_elasticsearch_max_mem_size=6g
- 儲存檔案。
- 執行下列指令:
/opt/apigee/apigee-service/bin/apigee-service apigee-elasticsearch restart
設定成功完成節點上的設定。
安裝 API BaaS 堆疊:機器 4、5 和 6
如要在其節點上安裝 API BaaS Stack:
- 透過網際網路或非網際網路程序,在節點上安裝 Edge Apigee-setup 公用程式。詳情請參閱「安裝 Edge Apigee 設定公用程式」。
- 在命令提示字元中,執行設定指令碼:
/opt/apigee/apigee-setup/bin/setup.sh -p b -f configFile
「-p b」選項會指定安裝 API BaaS 堆疊。設定檔必須可供「Apigee」使用者存取或讀取。
安裝程式擷取正確的管理員憑證後,就會安裝 Tomcat、建立 API BaaS 命名空間,並在伺服器上設定 API BaaS Stack。SMTP 也被設為允許使用者介面傳送密碼確認電子郵件。
安裝 API BaaS 入口網站:機器 7
如要安裝 API BaaS 入口網站:
- 透過網際網路或非網際網路程序,在節點上安裝 Edge Apigee-setup 公用程式。詳情請參閱「安裝 Edge Apigee 設定公用程式」。
- 在命令提示字元中,執行設定指令碼:
/opt/apigee/apigee-setup/bin/setup.sh -p p -f configFile
「-p p」選項會指定安裝 API BaaS 入口網站。設定檔必須可供「Apigee」使用者存取或讀取。
安裝程式會啟動 Nginx 網路伺服器,並完成 API BaaS 入口網站設定。
- 後續步驟視安裝內容而定。
- 如果您在入口網站堆疊堆疊節點前面設有負載平衡器,下一節將說明如何為負載平衡器設定 API BaaS。
- 如果您在入口網站堆疊堆疊節點前面沒有負載平衡器,請按照下方「加入新機構」一節的說明加入機構。
記下 API BaaS 入口網站網址。這是你在瀏覽器中輸入的網址,用來存取 API BaaS 入口網站使用者介面。
為 Stack 或 Portal 負載平衡器設定 API BaaS 節點
如果您在 Stack 或 Portal 節點之前新增負載平衡器,則必須使用正確的負載平衡器網址設定節點。舉例來說,Stack 節點需要以下資訊才能派上用場:
- 在 BaaS API 要求的回應中加入網址。
- 在重設密碼或傳送其他通知時,在電子郵件範本中新增連結。
- 將使用者重新導向至特定入口網站頁面。
如果您在 Stack 節點之前使用負載平衡器,請在
/opt/apigee/customer/application/usergrid.properties
中設定下列屬性:usergrid-deployment_usergrid.api.url.base=http://localhost:8080
將 http://localhost:8080 替換成負載平衡器的網址。如果負載平衡器設為使用傳輸層安全標準 (TLS),請使用 HTTPS 通訊協定。只有在使用非標準通訊埠時,才需要加入通訊埠;也就是說,HTTP 通訊埠 80 除外,HTTPS 通訊埠 443 除外。
如果您在 Stack 節點前方使用負載平衡器,也必須在
/opt/apigee/customer/application/portal.properties
中設定下列屬性:baas.portal.config.overrideUrl=http://localhost:8080
將 http://localhost:8080 替換為 Stack 的負載平衡器網址。
如果您在入口網站節點前使用負載平衡器,請在
usergrid.properties
中設定下列屬性:usergrid-deployment_portal.url=http://localhost:9000
將 http://localhost:9000 替換為負載平衡器的網址。如果負載平衡器設為使用傳輸層安全標準 (TLS),請使用 HTTPS 通訊協定。只有在使用非標準通訊埠時,才需要加入通訊埠;也就是說,HTTP 通訊埠 80 除外,HTTPS 通訊埠 443 除外。
編輯
usergrid.properties
和portal.properties
後:- 設定堆疊節點:
/opt/apigee/apigee-service/bin/apigee-service baas-usergrid configure
- 重新啟動 BaaS 堆疊:
/opt/apigee/apigee-service/bin/apigee-service baas-usergrid restart
- 如果您修改了
portal.properties
,請設定入口網站節點:/opt/apigee/apigee-service/bin/apigee-service baas-portal configure
- 重新啟動 BaaS 入口網站:
/opt/apigee/apigee-service/bin/apigee-service baas-portal restart
為新機構入職
新手上路程序是建立機構和機構管理員。建立機構和機構管理員之後,您可以登入 API BaaS 入口網站 UI 並向 API BaaS REST API 提出要求。
建立機構時,機構管理員的電子郵件地址如下:
- (必須與系統管理員的電子郵件地址不同)。
- 名稱不得重複。也就是說,您無法為機構管理員使用相同的電子郵件地址建立兩個機構。不過,建立機構後,您可以新增其他管理員,讓多個機構重複使用。
如要執行新手上路程序,請使用
create_org_and_user.py
Python 指令碼。叫用沒有指令列引數的指令碼,會提示您查看所有資訊:python create_org_and_user.py
或者,您也可以將任何或所有選項做為指令列引數傳遞。系統會提示您輸入指令列中缺少的任何資訊:
python create_org_and_user.py -o '<org name>' python create_org_and_user.py -o '<org name>' -a '<new admin email>' -p '<new admin password>'
如何建立機構,請按照下列步驟操作:
- 將目錄變更為
/opt/apigee/baas-usergrid/bin
。 - 叫用
create_org_and_user.py
Python 指令碼。系統會提示您輸入 BaaS 系統管理員的使用者名稱和密碼,確保只有系統管理員才能執行。
- 在網路瀏覽器中安裝 API 標記入口網站網址時,使用您登入的網址登入 API BaaS 入口網站。如要存取入口網站,請透過下列格式輸入 API BaaS 入口網站網址:
http://portalExternalIP:9000/
- 入口網站登入畫面顯示時,您可以:
- 使用機構管理員的使用者名稱和密碼登入。
- 使用系統管理員的使用者名稱和密碼登入。
存取 API BaaS REST API
如要存取 API BaaS REST API,請使用下列表單中的網址:
https://loadBalancerIP:8080/your-org/your-app
在開發環境中,您可以在單一節點中安裝所有 API BaaS 元件,代表只有一個 API BaaS 堆疊。或者,您可能有一個小型 API 的堆疊 BaaS 堆疊節點,沒有負載平衡器。在這類環境中,您可以直接呼叫 API BaaS 堆疊節點:
curl -v "http://portalExternalIP:8080/status"
如要進一步瞭解如何開始使用 API BaaS 入口網站,請參閱 Apigee 說明文件:http://apigee.com/docs/content/build-apps-home。
- Open