本發(fā)明涉及通信技術(shù)領(lǐng)域,更具體地說,涉及一種負(fù)載均衡裝置和方法。
背景技術(shù):
在市場上普遍使用的是通過NGNIX來進(jìn)行軟件上的負(fù)載均衡,當(dāng)網(wǎng)站的規(guī)模較大時(shí),往往會(huì)進(jìn)行服務(wù)的拆分,各個(gè)服務(wù)獨(dú)立部署,并通過遠(yuǎn)程調(diào)用的方式來進(jìn)行協(xié)同工作。隨著系統(tǒng)的繼續(xù)擴(kuò)大和演進(jìn),服務(wù)器的數(shù)量會(huì)增多,相對應(yīng)的NGNIX軟件的數(shù)量也會(huì)增多,其相應(yīng)的NGNIX部署與配置工作也會(huì)增加,這會(huì)導(dǎo)致維護(hù)成本變高,單點(diǎn)故障的風(fēng)險(xiǎn)也隨之增加。
技術(shù)實(shí)現(xiàn)要素:
本發(fā)明要解決的技術(shù)問題在于如何避免現(xiàn)有技術(shù)中通過NGNIX來進(jìn)行軟件上的負(fù)載均衡而導(dǎo)致的維護(hù)成本高,故障風(fēng)險(xiǎn)大的問題;針對該技術(shù)問題,提供一種負(fù)載均衡裝置,包括:
監(jiān)控模塊,用于通過分布式服務(wù)框架集群監(jiān)控各個(gè)服務(wù)器;
接收模塊,用于接收來自客戶端的接入請求;
發(fā)送模塊,用于根據(jù)所述客戶端的接入請求將相應(yīng)的所述服務(wù)器的服務(wù)列表發(fā)送至所述客戶端;
接入模塊,用于根據(jù)所述服務(wù)列表將客戶端接入相應(yīng)的所述服務(wù)器。
可選的,還包括注冊模塊,用于在各個(gè)所述服務(wù)器中編寫分布式服務(wù)框架的注冊代碼,并基于所述注冊代碼向分布式服務(wù)框架集群進(jìn)行注冊;注冊成功后,接收所述分布式服務(wù)框架集群的監(jiān)控。
可選的,所述注冊模塊還用于:在所述服務(wù)器啟動(dòng)時(shí),通過所述注冊代碼調(diào)用分布式服務(wù)框架集群,直接向所述分布式服務(wù)框架集群注冊所述服務(wù)器的服務(wù)器信息。
可選的,所述監(jiān)控模塊還用于:
監(jiān)控各所述服務(wù)器與所述分布式服務(wù)框架集群的連接情況,并將連接失敗的所述服務(wù)器從所述服務(wù)列表中移除。
可選的,還包括緩存模塊,用于將所述服務(wù)列表緩存至所述客戶端中。
本發(fā)明還提供一種負(fù)載均衡方法,包括:
通過分布式服務(wù)框架集群監(jiān)控各個(gè)服務(wù)器;
接收來自客戶端的接入請求,并根據(jù)所述客戶端的接入請求將相應(yīng)的所述服務(wù)器的服務(wù)列表發(fā)送至所述客戶端;
根據(jù)所述服務(wù)列表將所述客戶端接入相應(yīng)的所述服務(wù)器。
可選的,在所述通過分布式服務(wù)框架集群監(jiān)控各個(gè)服務(wù)器之前,還包括:在各個(gè)所述服務(wù)器中編寫分布式服務(wù)框架的注冊代碼,并基于所述注冊代碼向分布式服務(wù)框架集群進(jìn)行注冊;注冊成功后,接受所述分布式服務(wù)框架集群的監(jiān)控。
可選的,所述基于所述注冊代碼向分布式服務(wù)框架集群進(jìn)行注冊包括:在所述服務(wù)器啟動(dòng)時(shí),通過所述注冊代碼調(diào)用分布式服務(wù)框架集群,直接向所述分布式服務(wù)框架集群注冊所述服務(wù)器的服務(wù)器信息。
可選的,所述通過分布式服務(wù)框架集群監(jiān)控各個(gè)服務(wù)器包括:
監(jiān)控各所述服務(wù)器與所述分布式服務(wù)框架集群的連接情況,并將連接失敗的所述服務(wù)器從所述服務(wù)列表中移除。
可選的,在所述根據(jù)所述客戶端的接入請求將相應(yīng)的所述服務(wù)器的服務(wù)列表發(fā)送至所述客戶端之后,還包括:將所述服務(wù)列表緩存至所述客戶端中。
有益效果
本發(fā)明提供了一種負(fù)載均衡裝置和方法,通過分布式服務(wù)框架集群監(jiān)控各個(gè)服務(wù)器,接收來自客戶端的接入請求,并根據(jù)接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送給客戶端,然后根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。通過本發(fā)明的實(shí)施,通過分布式服務(wù)框架集群可以減少單點(diǎn)故障,同時(shí)也降低了維護(hù)所需的成本,此外,分布式服務(wù)框架集群不需要?jiǎng)討B(tài)的配置相關(guān)信息,節(jié)約了大量的時(shí)間。
附圖說明
下面將結(jié)合附圖及實(shí)施例對本發(fā)明作進(jìn)一步說明,附圖中:
圖1為本發(fā)明第一實(shí)施例提供的負(fù)載均衡裝置組成示意圖;
圖2為本發(fā)明第一實(shí)施例提供的通過zookeeper集群監(jiān)控各個(gè)服務(wù)器的示意圖;
圖3為本發(fā)明第二實(shí)施例提供的負(fù)載均衡方法流程圖;
圖4為本發(fā)明第三實(shí)施例提供的負(fù)載均衡方法流程圖。
具體實(shí)施方式
應(yīng)當(dāng)理解,此處所描述的具體實(shí)施例僅僅用以解釋本發(fā)明,并不用于限定本發(fā)明。
實(shí)施例一
圖1為本實(shí)施例一提供的一種負(fù)載均衡裝置組成示意圖,具體包括:
監(jiān)控模塊101,用于通過分布式服務(wù)框架(zookeeper)集群監(jiān)控各個(gè)服務(wù)器;
接收模塊102,用于接收來自客戶端的接入請求;
發(fā)送模塊103,用于根據(jù)客戶端的接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送客戶端;
接入模塊104,用于根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。
zookeeper是一個(gè)分布式的,開放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),它是一個(gè)為分布式應(yīng)用提供一致性服務(wù)器的軟件,提供的功能包括但不限于:配置維護(hù)、域名服務(wù)、分布式同步、組服務(wù)等等。以配置維護(hù)為例,當(dāng)一組代碼應(yīng)用于多個(gè)服務(wù)器時(shí),由于各個(gè)服務(wù)器的ip地址、接口等的差異,實(shí)際配置文件是不盡相同的,通過zookeeper集群則可以直接根據(jù)不同的服務(wù)器編寫配置文件,無需再一一寫入相應(yīng)的配置文件。
在本實(shí)施例中,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器,即利用zookeeper與各個(gè)服務(wù)器相連,監(jiān)測各個(gè)服務(wù)器的當(dāng)前的狀態(tài),包括服務(wù)器的運(yùn)行情況、ip地址、端口信息等等,其中,服務(wù)器的運(yùn)行情況包括正常運(yùn)行和連接失敗等等,當(dāng)某臺(tái)服務(wù)器與zookeeper之間不可達(dá),死機(jī)或者其他原因無法連上,則可能認(rèn)為該服務(wù)器出現(xiàn)的服務(wù)故障。
在本實(shí)施例中,為了使zookeeper集群可以監(jiān)測各個(gè)服務(wù)器,可選的,還可以包括搭建模塊105,用于搭建zookeeper集群的相關(guān)環(huán)境,并下載相關(guān)的工具包。也就是說,首先,將zookeeper集群建立起來,設(shè)置相關(guān)的硬件信息,并寫入相應(yīng)的軟件代碼等信息,保證zookeeper集群的成功建立與正常運(yùn)行。
此外,還可以包括注冊模塊106,用于在各個(gè)服務(wù)器中編寫zookeeper的注冊代碼,并基于注冊代碼向zookeeper集群進(jìn)行注冊;注冊成功后,接收zookeeper集群的監(jiān)控。為了使zookeeper監(jiān)控相應(yīng)的服務(wù)器,需要將各個(gè)服務(wù)器向zookeeper進(jìn)行注冊;注冊過程可以通過用戶手動(dòng)來進(jìn)行,也可以通過在各個(gè)服務(wù)器中編寫注冊代碼,即在各個(gè)服務(wù)器的應(yīng)用程序中編寫注冊代碼,讓程序自啟動(dòng)后自動(dòng)調(diào)用該注冊代碼來向zookeeper集群進(jìn)行相關(guān)的注冊動(dòng)作,即注冊模塊106還可以用于:在服務(wù)器啟動(dòng)時(shí),通過注冊代碼調(diào)用zookeeper集群,直接向zookeeper集群注冊服務(wù)器的服務(wù)器信息。服務(wù)器信息可以包括服務(wù)器的ip地址、端口等等信息。
注冊成功后,意味著服務(wù)器和zookeeper之間已經(jīng)建立連接,同時(shí)也意味著服務(wù)器已經(jīng)處于zookeeper集群的監(jiān)控之下,zookeeper集群可以實(shí)時(shí)監(jiān)測并判斷所連的服務(wù)器的狀態(tài),根據(jù)服務(wù)器的ip地址和端口信息生成相應(yīng)的服務(wù)列表。請參考圖2,圖2示出了通過zookeeper集群監(jiān)控各個(gè)服務(wù)器的示意圖。
服務(wù)列表至少可以提供相應(yīng)的服務(wù)器的ip地址信息,還可以包括其他的附加信息,比如該服務(wù)器的ip地址的優(yōu)先權(quán)信息等等,當(dāng)客戶端接入服務(wù)器時(shí)可以參考該優(yōu)先權(quán)信息來接入所需的服務(wù)器。
服務(wù)列表中對應(yīng)的服務(wù)器應(yīng)該是正常工作的服務(wù)器,在本實(shí)施例中,監(jiān)控模塊101還可以用于:監(jiān)控各個(gè)服務(wù)器與zookeeper集群的連接情況,并將連接失敗的服務(wù)器從服務(wù)列表中移除。當(dāng)某服務(wù)器由于不可達(dá)、死機(jī)或者種種其他原因?qū)е潞蛕ookeeper之間連接失敗,此時(shí)該服務(wù)器可以被認(rèn)為是故障服務(wù)器,可以將在服務(wù)列表中的該服務(wù)器的相關(guān)信息移除。此時(shí)的服務(wù)列表只含有其他連接正常的服務(wù)器的信息,從而使客戶端在接收到服務(wù)列表后可以正常接入所需的服務(wù)器,而不會(huì)出現(xiàn)接入了故障的服務(wù)器而導(dǎo)致的其他問題。
然后,有服務(wù)器和zookeeper之間不可達(dá)的情況,也會(huì)有zookeeper與服務(wù)器之間恢復(fù)連接的情況;當(dāng)服務(wù)器和zookeeper集群之間恢復(fù)連接時(shí),則可以將該服務(wù)器繼續(xù)添加至服務(wù)列表中。
在本實(shí)施例中,還可以包括緩存模塊107,用于將服務(wù)列表緩存至客戶端中。客戶端在接收到服務(wù)列表之后,為了后續(xù)處理的方便,將服務(wù)列表進(jìn)行緩存,那么在后續(xù)欲接入相應(yīng)的服務(wù)器時(shí),無需發(fā)起接入請求,可以直接根據(jù)緩存的服務(wù)列表接入相應(yīng)的服務(wù)器。而如果服務(wù)列表發(fā)生了變化,比如某臺(tái)服務(wù)器死機(jī)下線,或者新增加了服務(wù)器,zookeeper集群可以自動(dòng)通知該客戶端再次重新獲取服務(wù)列表,與此同時(shí),則可以將緩存的服務(wù)列表移除。
本實(shí)施例提供了一種負(fù)載均衡裝置,包括監(jiān)控模塊、接收模塊、發(fā)送模塊、接入模塊,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器,接收來自客戶端的接入請求,并根據(jù)接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送給客戶端,然后根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。通過本實(shí)施例的實(shí)施,通過zookeeper集群可以減少單點(diǎn)故障,同時(shí)也降低了維護(hù)所需的成本,此外,zookeeper集群不需要?jiǎng)討B(tài)的配置相關(guān)信息,節(jié)約了大量的時(shí)間。
實(shí)施例二
圖3為本實(shí)施例二提供的一種負(fù)載均衡方法流程圖,具體包括:
S301、通過zookeeper集群監(jiān)控各個(gè)服務(wù)器;
S302、接收來自客戶端的接入請求,并根據(jù)客戶端的接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送客戶端;
S303、根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。
zookeeper是一個(gè)分布式的,開放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),它是一個(gè)為分布式應(yīng)用提供一致性服務(wù)器的軟件,提供的功能包括但不限于:配置維護(hù)、域名服務(wù)、分布式同步、組服務(wù)等等。以配置維護(hù)為例,當(dāng)一組代碼應(yīng)用于多個(gè)服務(wù)器時(shí),由于各個(gè)服務(wù)器的ip地址、接口等的差異,實(shí)際配置文件是不盡相同的,通過zookeeper集群則可以直接根據(jù)不同的服務(wù)器編寫配置文件,無需再一一寫入相應(yīng)的配置文件。
在本實(shí)施例中,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器,即利用zookeeper與各個(gè)服務(wù)器相連,監(jiān)測各個(gè)服務(wù)器的當(dāng)前的狀態(tài),包括服務(wù)器的運(yùn)行情況、ip地址、端口信息等等,其中,服務(wù)器的運(yùn)行情況包括正常運(yùn)行和連接失敗等等,當(dāng)某臺(tái)服務(wù)器與zookeeper之間不可達(dá),死機(jī)或者其他原因無法連上,則可能認(rèn)為該服務(wù)器出現(xiàn)的服務(wù)故障。
在本實(shí)施例中,為了使zookeeper集群可以監(jiān)測各個(gè)服務(wù)器,可選的,在通過zookeeper集群監(jiān)控各個(gè)服務(wù)器之前,還可以包括:搭建zookeeper集群的相關(guān)環(huán)境,并下載相關(guān)的工具包。也就是說,首先,將zookeeper集群建立起來,設(shè)置相關(guān)的硬件信息,并寫入相應(yīng)的軟件代碼等信息,保證zookeeper集群的成功建立與正常運(yùn)行。
此外,在本實(shí)施例中,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器之前,還可以包括:在各個(gè)服務(wù)器中編寫zookeeper的注冊代碼,并基于注冊代碼向zookeeper集群進(jìn)行注冊;注冊成功后,接收zookeeper集群的監(jiān)控。為了使zookeeper監(jiān)控相應(yīng)的服務(wù)器,需要將各個(gè)服務(wù)器向zookeeper進(jìn)行注冊;注冊過程可以通過用戶手動(dòng)來進(jìn)行,也可以通過在各個(gè)服務(wù)器中編寫注冊代碼,即在各個(gè)服務(wù)器的應(yīng)用程序中編寫注冊代碼,讓程序自啟動(dòng)后自動(dòng)調(diào)用該注冊代碼來向zookeeper集群進(jìn)行相關(guān)的注冊動(dòng)作,即:基于注冊代碼向zookeeper集群進(jìn)行注冊包括:在服務(wù)器啟動(dòng)時(shí),通過注冊代碼調(diào)用zookeeper集群,直接向zookeeper集群注冊服務(wù)器的服務(wù)器信息。
注冊成功后,意味著服務(wù)器和zookeeper之間已經(jīng)建立連接,同時(shí)也意味著服務(wù)器已經(jīng)處于zookeeper集群的監(jiān)控之下,zookeeper集群可以實(shí)時(shí)監(jiān)測并判斷所連的服務(wù)器的狀態(tài),根據(jù)服務(wù)器的ip地址和端口信息生成相應(yīng)的服務(wù)列表。
服務(wù)列表至少可以提供相應(yīng)的服務(wù)器的ip地址信息,還可以包括其他的附加信息,比如該服務(wù)器的ip地址的優(yōu)先權(quán)信息等等,當(dāng)客戶端接入服務(wù)器時(shí)可以參考該優(yōu)先權(quán)信息來接入所需的服務(wù)器。
服務(wù)列表中對應(yīng)的服務(wù)器應(yīng)該是正常工作的服務(wù)器,在本實(shí)施例中,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器還可以包括:監(jiān)控各個(gè)服務(wù)器與zookeeper集群的連接情況,并將連接失敗的服務(wù)器從服務(wù)列表中移除。當(dāng)某服務(wù)器由于不可達(dá)、死機(jī)或者種種其他原因?qū)е潞蛕ookeeper之間連接失敗,此時(shí)該服務(wù)器可以被認(rèn)為是故障服務(wù)器,可以將在服務(wù)列表中的該服務(wù)器的相關(guān)信息移除。此時(shí)的服務(wù)列表只含有其他連接正常的服務(wù)器的信息,從而使客戶端在接收到服務(wù)列表后可以正常接入所需的服務(wù)器,而不會(huì)出現(xiàn)接入了故障的服務(wù)器而導(dǎo)致的其他問題。
然后,有服務(wù)器和zookeeper之間不可達(dá)的情況,也會(huì)有zookeeper與服務(wù)器之間恢復(fù)連接的情況;當(dāng)服務(wù)器和zookeeper集群之間恢復(fù)連接時(shí),則可以將該服務(wù)器繼續(xù)添加至服務(wù)列表中。
在本實(shí)施例中,在根據(jù)客戶端的接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送至客戶端之后,還可以包括:將服務(wù)列表緩存至客戶端中??蛻舳嗽诮邮盏椒?wù)列表之后,為了后續(xù)處理的方便,將服務(wù)列表進(jìn)行緩存,那么在后續(xù)欲接入相應(yīng)的服務(wù)器時(shí),無需發(fā)起接入請求,可以直接根據(jù)緩存的服務(wù)列表接入相應(yīng)的服務(wù)器。而如果服務(wù)列表發(fā)生了變化,比如某臺(tái)服務(wù)器死機(jī)下線,或者新增加了服務(wù)器,zookeeper集群可以自動(dòng)通知該客戶端再次重新獲取服務(wù)列表,與此同時(shí),則可以將緩存的服務(wù)列表移除。
本實(shí)施例提供了一種負(fù)載均衡方法,通過zookeeper集群監(jiān)控各個(gè)服務(wù)器,接收來自客戶端的接入請求,并根據(jù)接入請求將相應(yīng)的服務(wù)器的服務(wù)列表發(fā)送給客戶端,然后根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。通過本實(shí)施例的實(shí)施,通過zookeeper集群可以減少單點(diǎn)故障,同時(shí)也降低了維護(hù)所需的成本,此外,zookeeper集群不需要?jiǎng)討B(tài)的配置相關(guān)信息,節(jié)約了大量的時(shí)間。
第三實(shí)施例
圖4為本實(shí)施例三提供的一種負(fù)載均衡方法流程圖,具體包括:
S401、搭建zookeeper集群的相關(guān)環(huán)境,并下載相關(guān)的工具包;
這是zookeeper的初始化過程,包括創(chuàng)建zookeeper相關(guān)的硬件,并寫入所需的軟件代碼等信息。
S402、在各個(gè)服務(wù)器中編寫zookeeper的注冊代碼;
S403、啟動(dòng)服務(wù)器,通過注冊代碼調(diào)用zookeeper集群,直接向zookeeper集群注冊服務(wù)器的服務(wù)器信息;
通過在服務(wù)器中編寫注冊代碼,可以讓服務(wù)器在啟動(dòng)時(shí)就直接調(diào)用zookeeper集群進(jìn)行注冊;除此之外,注冊過程也可以通過用戶手動(dòng)來進(jìn)行。
S404、注冊成功后,各服務(wù)器接受zookeeper集群的監(jiān)控;
注冊成功后,意味著服務(wù)器和zookeeper之間已經(jīng)建立連接,同時(shí)也意味著服務(wù)器已經(jīng)處于zookeeper集群的監(jiān)控之下,zookeeper集群可以實(shí)時(shí)監(jiān)測并判斷所連的服務(wù)器的狀態(tài),根據(jù)服務(wù)器的ip地址和端口信息生成相應(yīng)的服務(wù)列表;服務(wù)列表至少可以提供相應(yīng)的服務(wù)器的ip地址信息,還可以包括其他的附加信息,比如該服務(wù)器的ip地址的優(yōu)先權(quán)信息等等,當(dāng)客戶端接入服務(wù)器時(shí)可以參考該優(yōu)先權(quán)信息來接入所需的服務(wù)器。
S405、zookeeper集群接收來自客戶端的接入請求,并根據(jù)接入請求將服務(wù)列表發(fā)送給客戶端;
zookeeper集群監(jiān)控各個(gè)服務(wù)器時(shí),當(dāng)發(fā)現(xiàn)某個(gè)服務(wù)器由于不可達(dá)、死機(jī)或者種種其他原因?qū)е潞蛕ookeeper之間連接失敗,此時(shí)該服務(wù)器可以被認(rèn)為是故障服務(wù)器,可以將在服務(wù)列表中的該服務(wù)器的相關(guān)信息移除。此時(shí)的服務(wù)列表只含有其他連接正常的服務(wù)器的信息,從而使客戶端在接收到服務(wù)列表后可以正常接入所需的服務(wù)器,而不會(huì)出現(xiàn)接入了故障的服務(wù)器而導(dǎo)致的其他問題;當(dāng)服務(wù)器和zookeeper集群之間恢復(fù)連接時(shí),則可以將該服務(wù)器繼續(xù)添加至服務(wù)列表中。
S406、根據(jù)服務(wù)列表將客戶端接入相應(yīng)的服務(wù)器。
客戶端在接收到服務(wù)列表之后,為了后續(xù)處理的方便,將服務(wù)列表進(jìn)行緩存,那么在后續(xù)欲接入相應(yīng)的服務(wù)器時(shí),無需發(fā)起接入請求,可以直接根據(jù)緩存的服務(wù)列表接入相應(yīng)的服務(wù)器。而如果服務(wù)列表發(fā)生了變化,比如某臺(tái)服務(wù)器死機(jī)下線,或者新增加了服務(wù)器,zookeeper集群可以自動(dòng)通知該客戶端再次重新獲取服務(wù)列表,與此同時(shí),則可以將緩存的服務(wù)列表移除。
通過以上的實(shí)施方式的描述,本領(lǐng)域的技術(shù)人員可以清楚地了解到上述實(shí)施例方法可借助軟件加必需的通用硬件平臺(tái)的方式來實(shí)現(xiàn),當(dāng)然也可以通過硬件,但很多情況下前者是更佳的實(shí)施方式?;谶@樣的理解,本發(fā)明的技術(shù)方案本質(zhì)上或者說對現(xiàn)有技術(shù)做出貢獻(xiàn)的部分可以以軟件產(chǎn)品的形式體現(xiàn)出來,該計(jì)算機(jī)軟件產(chǎn)品存儲(chǔ)在一個(gè)存儲(chǔ)介質(zhì)(如ROM/RAM、磁碟、光盤)中,包括若干指令用以使得一臺(tái)終端設(shè)備(可以是手機(jī),計(jì)算機(jī),服務(wù)器,空調(diào)器,或者網(wǎng)絡(luò)設(shè)備等)執(zhí)行本發(fā)明各個(gè)實(shí)施例所述的方法。
上面結(jié)合附圖對本發(fā)明的實(shí)施例進(jìn)行了描述,但是本發(fā)明并不局限于上述的具體實(shí)施方式,上述的具體實(shí)施方式僅僅是示意性的,而不是限制性的,本領(lǐng)域的普通技術(shù)人員在本發(fā)明的啟示下,在不脫離本發(fā)明宗旨和權(quán)利要求所保護(hù)的范圍情況下,還可做出很多形式,這些均屬于本發(fā)明的保護(hù)之內(nèi)。