1.在主機(jī)執(zhí)行以下命令
iptables -A INPUT -i docker0 -j ACCEPT
2.進(jìn)入容器,執(zhí)行命令
root@fdbbff27a91c:/# ip route
default via 172.17.0.1 dev eth0
172.17.0.0/16 dev eth0 proto kernel scope link src 172.17.0.2
得到 172.17.0.1 ,可以通過該地址訪問宿主
具體可參考:
https://stackoverflow.com/que...
有幾種方式可以做到
1、最簡(jiǎn)單的方式,開一個(gè)worker進(jìn)程即監(jiān)聽tcp,又監(jiān)聽websocket,這樣在一個(gè)進(jìn)程里方便互相操作連接傳遞數(shù)據(jù)
use Workerman\Worker;
// 監(jiān)聽tcp端口,硬件連這個(gè)端口
$iot_worker = new Worker('tcp://0.0.0.0:1234');
// 兩個(gè)協(xié)議互通這種方式只能單進(jìn)程
$iot_worker->count = 1;
// 進(jìn)程啟動(dòng)時(shí)增加一個(gè)5678端口的websocket協(xié)議的監(jiān)聽,網(wǎng)頁用ws連5678端口
$iot_worker->onWorkerStart = function(){
// 聲明為全局變量,方便其它地方獲取到這個(gè)容器對(duì)象
global $ws_worker;
// 監(jiān)聽5678端口,協(xié)議websocket
$ws_worker = new Worker('websocket://0.0.0.0:5678');
// 網(wǎng)頁ws發(fā)來數(shù)據(jù)的時(shí)候的處理,可根據(jù)需要做處理,這里省略
$ws_worker->onMessage = function($ws_connection, $data){...};
$ws_worker->listen();
};
// 硬件發(fā)來消息的回調(diào)
$iot_worker->onMessage = function($connection, $data){
// 得到$ws_worker容器
global $ws_worker;
// 遍歷容器里的連接給所有網(wǎng)頁推送硬件發(fā)來的數(shù)據(jù)
foreach($ws_worker->connections as $ws_connection) {
$ws_connection->send($data);
}
};
// 啟動(dòng)workerman
Worker::runAll();
以上好處架構(gòu)清晰簡(jiǎn)單,但是只能單進(jìn)程
參考手冊(cè) http://doc.workerman.net/work...
2、開A B兩組worker進(jìn)程,A組進(jìn)程監(jiān)聽tcp,B組進(jìn)程監(jiān)聽websocket,利用channel通訊,可以參考workerman手冊(cè)
http://doc.workerman.net/comp...
http://doc.workerman.net/comp...
好處是可以分布式部署,可以多進(jìn)程多服務(wù)器集群
3、用gatewayWorker,開一組tcp端口的gateway進(jìn)程+一組websocket的進(jìn)程,參考手冊(cè)
http://doc2.workerman.net/mul...
好處是同樣可以分部署部署,可以多進(jìn)程多服務(wù)器集群,并且gatewayWorker提供了很多長(zhǎng)連接直接可以用的接口,非常方便
dns劫持+腳本注入
思路:
logger模塊里面有寫入文件的方法,將log的內(nèi)容寫入一個(gè)文件,然后shell腳本讀取log文件即可。
以下摘自: https://cuiqingcai.com/6080.html
import logging
logging.basicConfig(level=logging.DEBUG,
filename='output.log',
datefmt='%Y/%m/%d %H:%M:%S',
format='%(asctime)s - %(name)s - %(levelname)s - %(lineno)d - %(module)s - %(message)s')
logger = logging.getLogger(__name__)
logger.info('This is a log info')
logger.debug('Debugging')
logger.warning('Warning exists')
logger.info('Finish')
這里我們指定了輸出文件的名稱為 output.log,另外指定了日期的輸出格式,其中年月日的格式變成了 %Y/%m/%d,另外輸出的 format 格式增加了 lineno、module 這兩個(gè)信息,運(yùn)行之后便會(huì)生成一個(gè) output.log 的文件
是不是可以點(diǎn)擊還原按鈕的時(shí)候,改變一下state,在shouldComponentUpdate里面不止做props變化的檢測(cè),也考慮state的變化。
shouldComponentUpdate(nextProps, nextState)lsof -i: 端口號(hào)看看
有興趣可以看看我發(fā)過的文章,30分鐘理解GraphQL核心概念,具體的東西里面應(yīng)該都有涉及。
好吧,還是我來說說自己的解決方法吧。我用的 cocos creator v1.9.1
其實(shí)是自己一開始不熟悉 cocos creator ,熟悉了就很簡(jiǎn)單。
首先把 editbox 放到需要的場(chǎng)景中,這里場(chǎng)景命名為 main,給這個(gè)場(chǎng)景 main 掛上腳本 main.js,掛的意思就是在資源管理器中創(chuàng)建好 main.js 然后就用鼠標(biāo)拖動(dòng)到 canvas 的屬性檢查器的 script 上。
接著可以在 main.js 上的 properties 上寫
//這個(gè)名字按照自己訂就好,應(yīng)為你也要把層級(jí)管理器中的那個(gè) editbox 拖到 canvas 屬性管理器的對(duì)應(yīng)位置,掛上。
editbox:{
default: null,
type: cc.EditBox,
}
繼續(xù)把一個(gè)按鍵 button 放到場(chǎng)景中,同樣在層級(jí)管理器中選中這個(gè) button ,在屬性管理器中找到 Click Events 把 0 改成 1,這樣這個(gè)按鍵就會(huì)有一個(gè)執(zhí)行方法了,數(shù)值代表可以掛多少個(gè)方法,下面的就是拖動(dòng) canvas 到第一個(gè)框,第二個(gè)框是哪個(gè)腳本(js),第三個(gè)框是這個(gè)腳本下的方法。CustomEventData 是這個(gè) button 傳的 value
例如我們?cè)?main.js 上寫了個(gè) buttonEvent
properties:{
editbox:{
default: null,
type: cc.EditBox,
},
button:{
default: null,
type: cc.Button,
}
},
buttonEvent: function (target, value) {
// target 是按鍵自帶的事件,value 就是 CustomEventData
cc.log(target, value);
this.button.string = value;
}
按照上面的就是能把一個(gè)按鍵的值傳到 editbox 上面,模擬出虛擬鍵盤的輸入了
好了,以上是我的方法,假如有別的方法請(qǐng)不吝賜教,謝謝啦。
wget 使用 c 語言,而 nodejs 使用 javascript 語言。
c 語言運(yùn)行前得編譯成機(jī)器指令,而 javascript 是在運(yùn)行時(shí)通過解釋器把腳本轉(zhuǎn)換成機(jī)器指令。
這造成絕大部分情況下,c 語言的性能優(yōu)于 javascript。
另外,下載大文件(GB及以上)時(shí),不能使用類似于下面的代碼
var request = require('request');
request('http://xxx', function (error, response, body) {
// ...
});
這很可能造成內(nèi)存枯竭,應(yīng)該采用流處理,如
request('http://xxx').pipe(fs.createWriteStream('xxx'))折騰這個(gè)干嘛,上插件啊
jqprint
以前一個(gè)交換機(jī)就是一個(gè)LAN,一個(gè)LAN就是一個(gè)廣播域。
后來交換機(jī)支持VLAN了,每個(gè)VLAN就是一個(gè)廣播域了。
在用xlsx-style包的時(shí)候,貌似沒有ws['!rows']屬性,也就是說不能設(shè)置行的高度。。。
看來還是要想辦法獲取xlsx包的專業(yè)版了。
你可以去參考一下https://github.com/watchdog-framework/watchdog-framework的前端項(xiàng)目設(shè)計(jì),大概是這樣的一個(gè)思路:
后端返回給前端的響應(yīng):
{
"status": 1,
"data": {
"total": 114,
"size": 10,
"pages": 12,
"current": 1,
"records": [{
"id": "990145393943736321",
"username": "test",
"uid": "989416849999503361",
"ip": "222.209.86.19",
"ajax": 1,
"uri": "/account/sign-in",
"params": "[{\"password\":\"******\",\"username\":\"test\"}]",
"httpMethod": "POST",
"classMethod": "cn.licoy.wdog.core.controller.AccountController.signIn()",
"actionName": "登錄",
"createDate": 1524904033000
}]
},
"msg": "操作成功",
"timestamps": 1524904039383
}
其中
data.total代表總記錄數(shù)data.size代表每頁顯示數(shù)量data.current代表當(dāng)前頁data.pages代表總頁數(shù)其總頁數(shù)運(yùn)算公式為 Math.ceil(data.total/data.size)。
根據(jù)你的需求,可以用group_concat函數(shù),按prod_id分組顯示,SQL類似如下:
select proid_id,group_concat(t.name SEPARATOR ';') as tname from product as p ..... 結(jié)尾用 group by prod_id
這樣出來的結(jié)果類似:
proid_id tname
...
40 小松菜奈的世界
41 夏天最好暖暖包;小松菜奈的世界
...
這樣程序中$orw['tname']獲取的就是"夏天最好暖暖包;小松菜奈的世界",可以用explode函數(shù)分割為數(shù)組使用。
var jsonpCallback =
改成window.jsonpCallback
小程序生成二維碼需要appid和secret,你在A小程序里掉生成二維碼接口,里面填小程序B的appid和secret,就生成B的二維碼了
.opacity(@number){
/* older safari/Chrome browsers */
-webkit-opacity: @number/100;
/* Netscape and Older than Firefox 0.9 */
-moz-opacity: @number/100;
/* Safari 1.x (pre WebKit!) 老式khtml內(nèi)核的Safari瀏覽器*/
-khtml-opacity: @number/100;
/* IE9 + etc...modern browsers */
opacity: @number/100;
/* IE 4-9 */
filter:alpha(opacity=@number);
/*This works in IE 8 & 9 too*/
-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=@number);
/*IE4-IE9*/
filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=@number);
}推薦使用vscode,簡(jiǎn)單、好用
拆分成兩個(gè)組件
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問,美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。