最近我们的网络托管商(Domainfactory)更改了从外部访问我们的在线 mysql 数据库的方法。从简单的 ssh“端口转发”到“unixocks 隧道”。
ssh 调用如下所示(并且它有效!):
ssh -N -L 5001:/var/lib/mysql5/mysql5.sock ssh-user@ourdomain.tld
问题是:每次都必须输入密码。
过去,我使用 BitVise SSH 客户端创建配置文件(其中还存储加密密码)。只需双击个人资料,您就会自动登录。
不幸的是,“BitVise SSH 客户端”和“Putty”(plink.exe) 都不支持“Unixocks 隧道”功能/扩展,所以我不能再使用这些工具了。
有谁知道如何实现自动登录(脚本,工具,等等)?
访问数据库的员工无论如何都不能知道SSH密码!
我正在尝试在 Linux 中使用命名管道在 NodeJS 和 C 程序之间进行通信。我的服务器程序是用 NodeJS 编写的:
'use strict';
const net = require('net');
const pipename = '/tmp/pipe1';
const fs = require('fs');
let server = net.createServer(function(socket){
console.log('A new connection');
socket.on('data',function(data){
console.log(data.toString());
});
socket.on('end',function(){
console.log('Closed connection');
});
});
server.on('error',console.log);
fs.unlink(pipename,function(){
server.listen(pipename);
})
//Test unix-socket server:
setInterval(function(){
var stream = net.connect(pipename);
stream.on('error',console.log);
stream.write('hello');
stream.end();
},2000);
Run Code Online (Sandbox Code Playgroud)
但是,当我想在 NodeJS 服务器已经启动后打开 C 内部的管道时,我收到错误:
const char* pipename = "/tmp/pipe1";
int hPipe = open(pipename, O_WRONLY); //Error: No such device or address
Run Code Online (Sandbox Code Playgroud)
当我尝试去做时echo 'Hello World!' > …
我已经为我正在处理的项目添加了一个Unix域套接字.套接字有一个简单的功能,它只是广播代码从另一个设备中提取的数据,其思路是其他应用程序将能够从套接字读取这些数据.
我写了一个简单的服务器代码,当我在笔记本电脑上运行代码时,使用Ubuntu 10.04 VM,它运行得非常好.但是,当我将代码复制到嵌入式设备上时,我正在使用代码失败,当我的应用程序尝试写入套接字时代码退出.
在/var/log/messages我看到以下消息:
Dec 2 15:12:17 box local1.info my-app[17338]: Socket Opened
Dec 2 15:12:17 box local1.err my-app[17338]: Socket Failed
Dec 2 15:12:17 box local1.err my-app[17338]: Protocol wrong type for socket
Dec 2 15:12:38 box local1.info ./server[17178]: accept failed: Invalid argument
Run Code Online (Sandbox Code Playgroud)
这是服务器代码:
#include <stdio.h>
#include <sys/un.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <errno.h>
#include<syslog.h>
#define SV_SOCK_PATH "/tmp/rtig.sock" //path to be used by socket
#define BUF_SIZE 256 //Max length of string listened to
#define BACKLOG 5
int main(int argc, …Run Code Online (Sandbox Code Playgroud) 加载我的索引页面时收到以下错误:
致命错误:在第32行的/Applications/MAMP/htdocs/parse/helloworld/helloworld/libraries/Database.php中调用非对象的成员函数prepare()
我将把所有相关的代码放在下面,对不起,但是应该相当直接阅读.简短的版本是我正在练习PDO和PHP类,所以我正在重建我在不同机器上的现有项目.(这就是为什么索引文件中有很多调用更像控制器的原因).
我把头发拉到这里是因为它可以在我的另一台机器上工作,而且我可以告诉我这两个项目完全相同......我只是得到了这个错误.我在之前的项目中有这个,但那是因为我在配置文件中拼错了数据库...我100%肯定我没有再这样做但我不知道我还错过了什么 - 显然是PDO如果我var_dump它返回null,那么就不会产生类...任何和所有帮助都会非常感激(特别是如果它是关于我的PDO类风格我只是关注一个似乎有意义的博客).
编辑:经过一些调试后很明显,数据库类中的try块失败,因为无法建立连接.运行后$this->error = $e->getMessage()返回的内容很明显:
string(119)"SQLSTATE [HY000] [2002]无法通过套接字连接到本地MySQL服务器'/Applications/MAMP/tmp/mysql/mysql.sock'(2)"
正如下面接受的答案所述,错误表明localhost试图通过unix套接字连接,而mysqld无法接受unix套接字连接.
因此,最初的错误导致了最终的问题:当mysqld不接受unix套接字连接和/或为什么mysqld不接受unix套接字连接时,如何连接到unix套接字?
结束编辑.
这是我的(相关)PDO课程:
<?php
class Database {
private $host = DB_HOST;
private $user = DB_USER;
private $pass = DB_PASS;
private $dbname = DB_NAME;
private $dbh;
private $error;
private $stmt;
public function __construct() {
// Set DSN
$dsn = 'mysql:host=' . $this->host . ';dbname=' . $this->dbname;
// Set options
$options = array (
PDO::ATTR_PERSISTENT => true,
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
);
// Create a new PDO instanace …Run Code Online (Sandbox Code Playgroud)