我是创建cron工作的新手。刚刚开始涉足昨天。
我为当地房地产经纪人设计了一个网站,我的数据库中有一个字段,用于“状态”和“状态”。 (待售,待售,已售),' SoldDate' (如果没有出售,则为NULL),'可见' (布尔)。我正在尝试创建一个cron作业,每天检查一次出售的物业,这些物品是“销售日期”。过去时间超过30天,如果为真,则更改“可见”字样。字段为0(假)。
现在我只有一个测试脚本,它将一个值添加到名为' CRON'的虚拟数据库中。和时间戳。
我使用Codeigniter构建我的网站。以下是我的代码:
Cron控制器
class Cron extends MY_Controller {
public function __construct()
{
parent::__construct();
$this->load->model('cron_m');
}
public function index()
{
if(!$this->input->is_cli_request())
{
echo "This script can only be accessed via the command line" . PHP_EOL;
return;
}
$data = array('value' => 'test');
$this->cron_m->save($data);
echo 'saved!';
}
}
Frontend_Controller
class Frontend_Controller extends MY_Controller {
function __construct()
{
parent::__construct();
$this->load->helper('form');
$this->load->library('form_validation');
}
public function lock()
{
$this->load->library('session');
$this->load->model('user_m');
// Login check
$exception_uris = array(
'admin/user/login',
'admin/user/logout'
);
if (in_array(uri_string(), $exception_uris) == FALSE)
{
if ($this->user_m->loggedin() == FALSE)
{
$uri = $this->uri->uri_string();
$this->session->set_tempdata('uri', $uri);
redirect('admin/user/login');
}
}
}
}
MY_Controller
class MY_Controller extends CI_Controller {
public $data = array();
function __construct() {
parent::__construct();
$this->data['errors'] = array();
}
}
Cron_m模型
class Cron_m extends MY_Model {
public $_table_name = 'CRON';
protected $_order_by = 'id';
public function __construct()
{
parent::__construct();
}
}
MY_Model
class MY_Model extends CI_Model {
public $_table_name = '';
protected $_primary_key = 'id';
protected $_primary_filter = 'intval';
protected $_order_by = 'order';
function __construct()
{
parent::__construct();
}
public function save($data, $id = NULL)
{
//INSERT
if ($id === NULL)
{
!isset($data[$this->_primary_key]) || $data[$this->_primary_key] = NULL;
$this->db->set($data);
$this->db->insert($this->_table_name);
$id = $this->db->insert_id();
}
//UPDATE
else
{
$filter = $this->_primary_filter;
$id = $filter($id);
$this->db->set($data);
$this->db->where($this->_primary_key, $id);
$this->db->update($this->_table_name);
}
return $id;
}
}
的.htaccess
RewriteEngine on
RewriteCond $1 !^(index\.php|robots\.txt|assets|uploads|podcast\.xml)
RewriteRule ^(.*)$ /index.php/$1 [L]
我的本地机器上的一切正常,但是当我在我的网络服务器终端上运行代码时(php /home4/server_name/public_html/site_name/index.php cron)它没有运行并且给了我有关会话数据库发生数据库错误的错误。 " ip_address不能为空"
我不确定为什么要尝试创建会话数据。我还没有在我的Fronted_Controller中创建一个会话。
以下是我得到的错误:
Status: 500 Internal Server Error
Set-Cookie: ci_session=e9e9c8120a392b9009cd80196ce2fa2cabda516e; expires=Fri, 27-Nov-2015 01:42:33 GMT; path=/; HttpOnly
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-type: text/html; charset=UTF-8
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Database Error</title>
<style type="text/css">
::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }
body {
background-color: #fff;
margin: 40px;
font: 13px/20px normal Helvetica, Arial, sans-serif;
color: #4F5155;
}
a {
color: #003399;
background-color: transparent;
font-weight: normal;
}
h1 {
color: #444;
background-color: transparent;
border-bottom: 1px solid #D0D0D0;
font-size: 19px;
font-weight: normal;
margin: 0 0 14px 0;
padding: 14px 15px 10px 15px;
}
code {
font-family: Consolas, Monaco, Courier New, Courier, monospace;
font-size: 12px;
background-color: #f9f9f9;
border: 1px solid #D0D0D0;
color: #002166;
display: block;
margin: 14px 0 14px 0;
padding: 12px 10px 12px 10px;
}
#container {
margin: 10px;
border: 1px solid #D0D0D0;
box-shadow: 0 0 8px #D0D0D0;
}
p {
margin: 12px 15px 12px 15px;
}
</style>
</head>
<body>
<div id="container">
<h1>A Database Error Occurred</h1>
<p>Error Number: 1048</p><p>Column 'ip_address' cannot be null</p>
<p>INSERT INTO `CI_SESSIONS` (`id`, `ip_address`, `timestamp`, `data`) VALUES ('e9e9c8120a392b9009cd80196ce2fa2cabda516e', NULL, 1448581353, '__ci_last_regenerate|i:1448581353;')</p>
<p>Filename: libraries/Session/drivers/Session_database_driver.php</p><p>Line Number: 220</p>
</div>
</body>
我不知道我哪里出错了。如果您需要任何其他信息,请告诉我们。我会喜欢任何帮助或建议。
谢谢。
答案 0 :(得分:1)
这里的问题是您的安装已配置为使用数据库进行会话...并且由于您是从终端访问您的脚本,因此由于某种原因没有获得IP地址...出路将是不要将数据库用于会话数据(如果你的项目不需要它)。为此,请转到application/config/config.php
并将$config['sess_use_database'] = TRUE;
更改为$config['sess_use_database'] = FALSE;
那应该解决它。