Запросы Codeigniter извлекают кэшированные результаты (выбор результатов запроса не обновляется)

У меня есть программа для административной панели. У меня есть список предметов. Я удаляю один из списка и обновляю страницу, чтобы снова запустить запрос выбора. Но удаленный снова появляется там. хотя его не видно в phpmyadmin. Пробовал очищать кеш и много раз обновлял, но все равно. Добавление нового элемента также приводит к аналогичному результату. запрос выполняется успешно, но не обновляется при выборе запроса в codeignighter

база данных.php:

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'localhost',
    'username' => 'admin_tr_user',
    'password' => 'zxxxxxxxz',
    'database' => 'xyz_db',
    'dbdriver' => 'mysqli',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'),
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt' => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    'save_queries' => TRUE
);

Выберите весь метод в модель:

function get_apps() {

      $this->db->order_by("date", "desc");
      $query = $this->db->get('apps');


      return $query->result_array();

    }

Используете ли вы кеш на стороне сервера?

Lajos Arpad 24.02.2019 16:11

@LajosArpad Я полагаю, что-то подобное происходит. Где найти такой вариант?

Geon George 24.02.2019 16:13

Зависит от вашего сервера. Я полагаю, вы используете CloudFlare или что-то подобное. Вам нужно будет проверить настройки вашего сервера.

Lajos Arpad 24.02.2019 16:42

@LajosArpad Да, я использую cloudflare, но это не обслуживается через API. Codeigniter напрямую запрашивает базу данных. Я думаю, что это связано с mysql или php

Geon George 24.02.2019 17:01

Можете ли вы очистить кеш Cloudflare и сказать мне, сохраняется ли проблема?

Lajos Arpad 24.02.2019 17:23

Это не облачное пламя. Проверил уже. И я уже говорил вам, что это не через API. страница напрямую извлекает результат запроса в виде массива ab

Geon George 24.02.2019 17:36

Если это MySQL, вы сможете найти запись, выполнив запрос.

Lajos Arpad 24.02.2019 17:38

в какой СРЕДЕ вы находитесь? Почему бы просто не установить 'cache_on' => FALSE? И вы перезагружаете страницу результатов или используете какой-то ajax для обновления DOM?

Vickel 24.02.2019 18:07

ПОЧИНИЛ ЭТО! Это был кеш nginx, который обслуживал статические файлы без запуска php-скрипта каждый раз.

Geon George 24.02.2019 18:10
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
9
201
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я отвечаю на свой вопрос здесь:

Это был кеш nginx, вызывающий эту проблему. Я отредактировал конфигурацию Nginx, чтобы обойти кеш по умолчанию.

в /etc/nginx/nginx.conf

  # Cache bypass. I set the default from 0 to 1
    map $http_cookie $no_cache {
        default 1; 
        ~SESS 1;
        ~wordpress_logged_in 1;
    }

Другие вопросы по теме