(2006, 'MySQL server has gone away')
Request Method: | GET |
---|---|
Request URL: | http://chunom.org/pages/606A/ |
Django Version: | 2.0 |
Exception Type: | OperationalError |
Exception Value: | (2006, 'MySQL server has gone away') |
Exception Location: | /home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/connections.py in query, line 259 |
Python Executable: | /home/trung/venv/nom/bin/python3 |
Python Version: | 3.8.10 |
Python Path: | ['/home/trung/nom', '/home/trung/venv/nom/bin', '/usr/lib/python38.zip', '/usr/lib/python3.8', '/usr/lib/python3.8/lib-dynload', '/home/trung/venv/nom/lib/python3.8/site-packages', '/home/tng/nom'] |
Server time: | Fri, 29 Mar 2024 13:00:01 +0100 |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in _execute
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params)...
def _executemany(self, sql, param_list, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
return self.cursor.executemany(sql, param_list)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <django.db.backends.mysql.base.DatabaseWrapper object at 0x7f83160743d0>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0>}) |
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/mysql/base.py
in execute
def __init__(self, cursor):
self.cursor = cursor
def execute(self, query, args=None):
try:
# args is None means no string interpolation
return self.cursor.execute(query, args)...
except Database.OperationalError as e:
# Map some error codes to IntegrityError, since they seem to be
# misclassified and Django would prefer the more logical place.
if e.args[0] in self.codes_for_integrityerror:
raise utils.IntegrityError(*tuple(e.args))
raise
Variable | Value |
---|---|
args | ('', 'khác', '', '恪') |
query | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
self | <django.db.backends.mysql.base.CursorWrapper object at 0x7f83149de910> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/cursors.py
in execute
args = tuple(map(db.literal, args))
try:
query = query % args
except TypeError as m:
raise ProgrammingError(str(m))
assert isinstance(query, (bytes, bytearray))
res = self._query(query)...
return res
def executemany(self, query, args):
# type: (str, list) -> int
"""Execute a multi-row query.
Variable | Value |
---|---|
args | (b"''", b"'kh\xc3\xa1c'", b"''", b"'\xe6\x81\xaa'") |
db | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
query | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <MySQLdb.cursors.Cursor object at 0x7f83149de4c0> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/cursors.py
in _query
)
self._query(q)
return args
def _query(self, q):
db = self._get_db()
self._result = None
db.query(q)...
self._do_get_result(db)
self._post_get_result()
self._executed = q
return self.rowcount
def _fetch_row(self, size=1):
Variable | Value |
---|---|
db | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
q | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <MySQLdb.cursors.Cursor object at 0x7f83149de4c0> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/connections.py
in query
"""
return (cursorclass or self.cursorclass)(self)
def query(self, query):
# Since _mysql releases GIL while querying, we need immutable buffer.
if isinstance(query, bytearray):
query = bytes(query)
_mysql.connection.query(self, query)...
def _bytes_literal(self, bs):
assert isinstance(bs, (bytes, bytearray))
x = self.string_literal(bs) # x is escaped and quoted bytes
if self._binary_prefix:
return b"_binary" + x
Variable | Value |
---|---|
query | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
/home/trung/venv/nom/lib/python3.8/site-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@wraps(get_response)
def inner(request):
try:
response = get_response(request)...
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | OperationalError(2006, 'MySQL server has gone away') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f83156aa430>> |
request | <WSGIRequest: GET '/pages/606A/'> |
/home/trung/venv/nom/lib/python3.8/site-packages/django/core/handlers/base.py
in _get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)...
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
callback | <function page_glyph at 0x7f831528d550> |
callback_args | () |
callback_kwargs | {'glyph_hex': '606A'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f83154ab2e0>> |
request | <WSGIRequest: GET '/pages/606A/'> |
resolver | <URLResolver 'nom.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=nom.homepage.views.page_glyph, args=(), kwargs={'glyph_hex': '606A'}, url_name=glyph.hex, app_names=['homepage'], namespaces=['page']) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f83156aa430> |
wrapped_callback | <function page_glyph at 0x7f831528d550> |
/home/trung/venv/nom/lib/python3.8/site-packages/django/core/handlers/base.py
in _get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)...
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
callback | <function page_glyph at 0x7f831528d550> |
callback_args | () |
callback_kwargs | {'glyph_hex': '606A'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f83154ab2e0>> |
request | <WSGIRequest: GET '/pages/606A/'> |
resolver | <URLResolver 'nom.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=nom.homepage.views.page_glyph, args=(), kwargs={'glyph_hex': '606A'}, url_name=glyph.hex, app_names=['homepage'], namespaces=['page']) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f83156aa430> |
wrapped_callback | <function page_glyph at 0x7f831528d550> |
/home/trung/nom/nom/homepage/views.py
in page_glyph
'strokes_max': list['strokes_max'],
}
return render(request, "homepage/index.html", context)
def page_glyph(request, glyph_hex):
g = chr(int(glyph_hex, 16))
return page_glyph_literal(request, g)...
return redirect('/pages/%s/' % g)
def page_glyph_decimal(request, glyph_dec):
g = chr(int(glyph_dec[1]))
return redirect('/pages/%s/' % g)
Variable | Value |
---|---|
g | '恪' |
glyph_hex | '606A' |
request | <WSGIRequest: GET '/pages/606A/'> |
/home/trung/nom/nom/homepage/views.py
in page_glyph_literal
def page_glyph_decimal(request, glyph_dec):
g = chr(int(glyph_dec[1]))
return redirect('/pages/%s/' % g)
def page_glyph_literal(request, glyph):
glyph_hex = hex(ord(glyph)).replace("L","").replace("0x","").upper()
context = glyph_details(request, glyph_hex, type='', get_context=True)...
glyph = context['glyph']
if request.GET.get('charset'):
charset = request.GET.get('charset')
if charset == 'common' and glyph.category != 'simplified':
variant = glyph.convert('simplified')
Variable | Value |
---|---|
glyph | '恪' |
glyph_hex | '606A' |
request | <WSGIRequest: GET '/pages/606A/'> |
/home/trung/nom/nom/glyph/views.py
in glyph_details
'traditional': traditional,
'relaxed': relaxed,
'entry_list': entry_list,
'variants_list': variants_list,
'glyph_strokes_list': glyph_strokes_list,
'frequency': frequency,
'coverage': coverage,
'level': glyph.level(),...
'unihan_reading': unihan_reading,
'unihan_reading_list': unihan_reading_list,
'unihan_radical_strokes': radical_strokes.value,
'unihan_total_strokes': total_strokes.value,
'unihan_additional_strokes': additional_strokes,
'unihan_radical_number': radical_number,
Variable | Value |
---|---|
additional_strokes | 0 |
best_entry_frequency | 78 |
coverage | 34.764 |
e | <Entry: Entry object (876)> |
entry_list | [<Entry: Entry object (325)>, <Entry: Entry object (1741)>, <Entry: Entry object (876)>] |
f | 4530 |
frequency | 78 |
get_context | True |
glyph | <Glyph: Glyph object (305)> |
glyph_hex | '606A' |
glyph_list | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
glyph_strokes_list | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
kVietnamese | <QuerySet [<Reading: Reading object (54663)>]> |
list | [<Entry: Entry object (325)>, <Entry: Entry object (1741)>, <Entry: Entry object (876)>] |
radical_hex | None |
radical_number | '' |
radical_strokes | <RadicalStrokes: RadicalStrokes object (None)> |
reference | None |
relaxed | None |
request | <WSGIRequest: GET '/pages/606A/'> |
root_variant | <Glyph: Glyph object (305)> |
stroke_index | '' |
template | 'glyph/details.html' |
thread_list | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
total_strokes | <Meta: Meta object (None)> |
traditional | None |
type | '' |
unihan_reading | 'khác' |
unihan_reading_list | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
variants_list | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
word | 'khác' |
/home/trung/nom/nom/glyph/models.py
in level
if wordcounts.count() > 0:
coverage = wordcounts[0].coverage
return coverage
def freeze_level(self, commit=True):
self.tmp_level = int(self.level())
if commit: self.save()
def level(self):
coverage = self.max_coverage()...
lv = '0'
if coverage is not None:
if coverage <= 35: lv = '1'
elif coverage <= 60: lv = '2'
elif coverage <= 75: lv = '3'
elif coverage <= 90: lv = '4'
Variable | Value |
---|---|
self | <Glyph: Glyph object (305)> |
/home/trung/nom/nom/glyph/models.py
in max_coverage
pronounciations = [ self.label ]
if self.alternate is not None:
alts = self.alternate.split(",")
for alt in alts:
pronounciations.append(alt.strip(" \t"))
coverage = None
wordcounts = Wordcount.objects.filter(word__in=pronounciations, specifier__in=('',self.text_nom)).order_by('coverage')
if wordcounts.count() > 0:...
coverage = wordcounts[0].coverage
return coverage
def freeze_level(self, commit=True):
self.tmp_level = int(self.level())
if commit: self.save()
def level(self):
Variable | Value |
---|---|
alt | '' |
alts | [''] |
coverage | None |
pronounciations | ['khác', ''] |
self | <Glyph: Glyph object (305)> |
wordcounts | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/models/query.py
in count
If the QuerySet is already fully cached, return the length of the
cached results set to avoid multiple SELECT COUNT(*) calls.
"""
if self._result_cache is not None:
return len(self._result_cache)
return self.query.get_count(using=self.db)...
def get(self, *args, **kwargs):
"""
Perform the query and return a single object matching the given
keyword arguments.
"""
Variable | Value |
---|---|
self | Error in formatting: OperationalError: (2006, 'MySQL server has gone away') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/models/sql/query.py
in get_count
def get_count(self, using):
"""
Perform a COUNT() query using the current filter constraints.
"""
obj = self.clone()
obj.add_annotation(Count('*'), alias='__count', is_summary=True)
number = obj.get_aggregation(using, ['__count'])['__count']...
if number is None:
number = 0
return number
def has_filters(self):
return self.where
Variable | Value |
---|---|
obj | <django.db.models.sql.query.Query object at 0x7f83149de2e0> |
self | <django.db.models.sql.query.Query object at 0x7f83149de040> |
using | 'default' |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/models/sql/query.py
in get_aggregation
self._extra = {}
outer_query.clear_ordering(True)
outer_query.clear_limits()
outer_query.select_for_update = False
outer_query.select_related = False
compiler = outer_query.get_compiler(using)
result = compiler.execute_sql(SINGLE)...
if result is None:
result = [None] * len(outer_query.annotation_select)
converters = compiler.get_converters(outer_query.annotation_select.values())
result = next(compiler.apply_converters((result,), converters))
Variable | Value |
---|---|
added_aggregate_names | ['__count'] |
compiler | <django.db.backends.mysql.compiler.SQLCompiler object at 0x7f83149de130> |
has_existing_annotations | False |
has_limit | False |
outer_query | <django.db.models.sql.query.Query object at 0x7f83149de2e0> |
self | <django.db.models.sql.query.Query object at 0x7f83149de2e0> |
using | 'default' |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/models/sql/compiler.py
in execute_sql
else:
return
if chunked_fetch:
cursor = self.connection.chunked_cursor()
else:
cursor = self.connection.cursor()
try:
cursor.execute(sql, params)...
except Exception:
# Might fail for server-side cursors (e.g. connection closed)
cursor.close()
raise
if result_type == CURSOR:
Variable | Value |
---|---|
chunk_size | 100 |
chunked_fetch | False |
cursor | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
params | ('', 'khác', '', '恪') |
result_type | 'single' |
self | <django.db.backends.mysql.compiler.SQLCompiler object at 0x7f83149de130> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in execute
class CursorDebugWrapper(CursorWrapper):
# XXX callproc isn't instrumented at this time.
def execute(self, sql, params=None):
start = time()
try:
return super().execute(sql, params)...
finally:
stop = time()
duration = stop - start
sql = self.db.ops.last_executed_query(self.cursor, sql, params)
self.db.queries_log.append({
'sql': sql,
Variable | Value |
---|---|
__class__ | <class 'django.db.backends.utils.CursorDebugWrapper'> |
duration | 7.104873657226562e-05 |
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | 'None' |
start | 1711713601.8104153 |
stop | 1711713601.8104863 |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in execute
elif kparams is None:
return self.cursor.callproc(procname, params)
else:
params = params or ()
return self.cursor.callproc(procname, params, kparams)
def execute(self, sql, params=None):
return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)...
def executemany(self, sql, param_list):
return self._execute_with_wrappers(sql, param_list, many=True, executor=self._executemany)
def _execute_with_wrappers(self, sql, params, many, executor):
context = {'connection': self.db, 'cursor': self}
Variable | Value |
---|---|
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in _execute_with_wrappers
def executemany(self, sql, param_list):
return self._execute_with_wrappers(sql, param_list, many=True, executor=self._executemany)
def _execute_with_wrappers(self, sql, params, many, executor):
context = {'connection': self.db, 'cursor': self}
for wrapper in reversed(self.db.execute_wrappers):
executor = functools.partial(wrapper, executor)
return executor(sql, params, many, context)...
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
return self.cursor.execute(sql)
Variable | Value |
---|---|
context | {'connection': <django.db.backends.mysql.base.DatabaseWrapper object at 0x7f83160743d0>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0>} |
executor | <bound method CursorWrapper._execute of <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0>> |
many | False |
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in _execute
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params)...
def _executemany(self, sql, param_list, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
return self.cursor.executemany(sql, param_list)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <django.db.backends.mysql.base.DatabaseWrapper object at 0x7f83160743d0>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0>}) |
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/utils.py
in __exit__
db_exc_type = getattr(self.wrapper.Database, dj_exc_type.__name__)
if issubclass(exc_type, db_exc_type):
dj_exc_value = dj_exc_type(*exc_value.args)
# Only set the 'errors_occurred' flag for errors that may make
# the connection unusable.
if dj_exc_type not in (DataError, IntegrityError):
self.wrapper.errors_occurred = True
raise dj_exc_value.with_traceback(traceback) from exc_value...
def __call__(self, func):
# Note that we are intentionally not using @wraps here for performance
# reasons. Refs #21109.
def inner(*args, **kwargs):
with self:
Variable | Value |
---|---|
db_exc_type | <class 'MySQLdb._exceptions.OperationalError'> |
dj_exc_type | <class 'django.db.utils.OperationalError'> |
dj_exc_value | OperationalError(2006, 'MySQL server has gone away') |
exc_type | <class 'MySQLdb._exceptions.OperationalError'> |
exc_value | OperationalError(2006, 'MySQL server has gone away') |
self | <django.db.utils.DatabaseErrorWrapper object at 0x7f8314cf1340> |
traceback | <traceback object at 0x7f831465dac0> |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/utils.py
in _execute
def _execute(self, sql, params, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
if params is None:
return self.cursor.execute(sql)
else:
return self.cursor.execute(sql, params)...
def _executemany(self, sql, param_list, *ignored_wrapper_args):
self.db.validate_no_broken_transaction()
with self.db.wrap_database_errors:
return self.cursor.executemany(sql, param_list)
Variable | Value |
---|---|
ignored_wrapper_args | (False, {'connection': <django.db.backends.mysql.base.DatabaseWrapper object at 0x7f83160743d0>, 'cursor': <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0>}) |
params | ('', 'khác', '', '恪') |
self | <django.db.backends.utils.CursorDebugWrapper object at 0x7f83149de0d0> |
sql | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
/home/trung/venv/nom/lib/python3.8/site-packages/django/db/backends/mysql/base.py
in execute
def __init__(self, cursor):
self.cursor = cursor
def execute(self, query, args=None):
try:
# args is None means no string interpolation
return self.cursor.execute(query, args)...
except Database.OperationalError as e:
# Map some error codes to IntegrityError, since they seem to be
# misclassified and Django would prefer the more logical place.
if e.args[0] in self.codes_for_integrityerror:
raise utils.IntegrityError(*tuple(e.args))
raise
Variable | Value |
---|---|
args | ('', 'khác', '', '恪') |
query | ('SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN ' '(%s, %s) AND `wordcounts`.`specifier` IN (%s, %s))') |
self | <django.db.backends.mysql.base.CursorWrapper object at 0x7f83149de910> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/cursors.py
in execute
args = tuple(map(db.literal, args))
try:
query = query % args
except TypeError as m:
raise ProgrammingError(str(m))
assert isinstance(query, (bytes, bytearray))
res = self._query(query)...
return res
def executemany(self, query, args):
# type: (str, list) -> int
"""Execute a multi-row query.
Variable | Value |
---|---|
args | (b"''", b"'kh\xc3\xa1c'", b"''", b"'\xe6\x81\xaa'") |
db | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
query | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <MySQLdb.cursors.Cursor object at 0x7f83149de4c0> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/cursors.py
in _query
)
self._query(q)
return args
def _query(self, q):
db = self._get_db()
self._result = None
db.query(q)...
self._do_get_result(db)
self._post_get_result()
self._executed = q
return self.rowcount
def _fetch_row(self, size=1):
Variable | Value |
---|---|
db | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
q | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <MySQLdb.cursors.Cursor object at 0x7f83149de4c0> |
/home/trung/venv/nom/lib/python3.8/site-packages/MySQLdb/connections.py
in query
"""
return (cursorclass or self.cursorclass)(self)
def query(self, query):
# Since _mysql releases GIL while querying, we need immutable buffer.
if isinstance(query, bytearray):
query = bytes(query)
_mysql.connection.query(self, query)...
def _bytes_literal(self, bs):
assert isinstance(bs, (bytes, bytearray))
x = self.string_literal(bs) # x is escaped and quoted bytes
if self._binary_prefix:
return b"_binary" + x
Variable | Value |
---|---|
query | (b'SELECT COUNT(*) AS `__count` FROM `wordcounts` WHERE (`wordcounts`.`word` IN' b" ('', 'kh\xc3\xa1c') AND `wordcounts`.`specifier` IN ('', '\xe6\x81\xaa'))") |
self | <_mysql.connection open to '127.0.0.1' at 0x34de870> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'chunom.org' |
HTTP_REFERER | 'https://www.chunom.org/pages/606A/' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '34.239.185.22' |
PATH_INFO | '/pages/606A/' |
QUERY_STRING | '' |
RAW_URI | '/pages/606A/' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'chunom.org' |
SERVER_PORT | '80' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/20.1.0' |
gunicorn.socket | <socket.socket fd=10, family=AddressFamily.AF_UNIX, type=SocketKind.SOCK_STREAM, proto=0, laddr=/home/trung/nom/gunicorn.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f831492f970> |
wsgi.file_wrapper | '' |
wsgi.input | <gunicorn.http.body.Body object at 0x7f831492fdc0> |
wsgi.input_terminated | True |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
settings_live
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | (('Trung Nguyen', 'qt.nguyen@sevenmicro.de'),) |
ADMIN_MEDIA_PREFIX | '/static/media/' |
ALLOWED_HOSTS | ['*'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ('social_core.backends.google.GoogleOAuth2', 'social_core.backends.facebook.FacebookOAuth2', 'social_core.backends.twitter.TwitterOAuth', 'django.contrib.auth.backends.ModelBackend') |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/home/trung/nom' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CORS_ALLOW_CREDENTIALS | True |
CORS_ORIGIN_ALLOW_ALL | True |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', 'NAME': 'www_chunom_org', 'OPTIONS': {'charset': 'utf8mb4', 'init_command': "SET sql_mode='STRICT_TRANS_TABLES'", 'isolation_level': 'read committed'}, 'PASSWORD': '********************', 'PORT': '3306', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'www_chunom_org'}, 'sqlite': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.sqlite3', 'HOST': '127.0.0.1', 'NAME': '/home/trung/nom/nom.live', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '3306', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'nom'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%Y-%m-%d', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%Y', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M', '%m/%d/%y'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_CONTENT_TYPE | 'text/html' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'notify@chunom.org' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
DJANGO_BASE | '/home/trung/nom/' |
DJANGO_ROOT | '/home/trung/nom/nom/' |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'smtp.chunom.org' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | 'qt.nguyen@sevenmicro.com' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_CHARSET | 'utf-8' |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 10485760 |
FILE_UPLOAD_PERMISSIONS | None |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ('whitenoise.runserver_nostatic', 'django.contrib.staticfiles', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.sites', 'django.contrib.messages', 'corsheaders', 'django_markdownfield', 'nom.compose', 'nom.converter', 'nom.discuss', 'nom.document', 'nom.entry', 'nom.forum', 'nom.glyph', 'nom.homepage', 'nom.ime', 'nom.level', 'nom.blog', 'nom.samples', 'nom.shelf', 'nom.sheet', 'nom.timeline', 'nom.unihan', 'social_django') |
INTERNAL_IPS | [] |
LANGUAGES | (('en', 'English'), ('vi', 'Vietnamese'), ('de', 'German'), ('vi-xx', 'Chu Nom')) |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
LANGUAGE_CODE | 'en' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LOCALE_PATHS | ('/home/trung/nom/nom/locale',) |
LOGGING | {'disable_existing_loggers': True, 'formatters': {'simple': {'format': '%(levelname)s %(asctime)s %(module)s ' 'Line %(lineno)d: %(message)s'}, 'verbose': {'format': '%(levelname)s %(asctime)s %(module)s ' 'Line %(lineno)d: %(process)d %(thread)d ' '%(message)s'}}, 'handlers': {'console': {'class': 'logging.StreamHandler', 'formatter': 'simple', 'level': 'DEBUG'}, 'file': {'backupCount': 2, 'class': 'logging.handlers.RotatingFileHandler', 'filename': '/home/trung/nom/nom/logging.log', 'formatter': 'simple', 'level': 'DEBUG', 'maxBytes': 50000}, 'mail_admins': {'class': 'django.utils.log.AdminEmailHandler', 'formatter': 'simple', 'level': 'ERROR'}}, 'loggers': {'': {'handlers': ['file', 'console'], 'level': 'ERROR', 'propagate': True}}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/' |
LOGIN_URL | '/login/' |
LOGOUT_REDIRECT_URL | '/' |
LOGOUT_URL | '/logout/' |
MANAGERS | (('Trung Nguyen', 'qt.nguyen@sevenmicro.de'),) |
MARKDOWNX_EDITOR_RESIZABLE | False |
MARKDOWNX_IMAGE_MAX_SIZE | {'quality': 90, 'size': (800, 600)} |
MARKDOWNX_MARKDOWN_EXTENSIONS | ['markdown.extensions.extra'] |
MARKDOWNX_MEDIA_PATH | 'md-img/2024/03' |
MEDIA_ROOT | '/home/trung/nom/nom/_upload/' |
MEDIA_URL | '/upload/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ('django.middleware.security.SecurityMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.locale.LocaleMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'social_django.middleware.SocialAuthExceptionMiddleware') |
MIDDLEWARE_CLASSES | ('django.middleware.security.SecurityMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.locale.LocaleMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'social_django.middleware.SocialAuthExceptionMiddleware') |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'nom.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SEND_BROKEN_LINK_EMAILS | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 7776000 |
SESSION_COOKIE_DOMAIN | None |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'settings_live' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SITE_ID | 1 |
SOCIAL_AUTH_FACEBOOK_KEY | '********************' |
SOCIAL_AUTH_FACEBOOK_PROFILE_EXTRA_PARAMS | {'fields': 'id,name,email,age_range'} |
SOCIAL_AUTH_FACEBOOK_SCOPE | ['email'] |
SOCIAL_AUTH_FACEBOOK_SECRET | '********************' |
SOCIAL_AUTH_GOOGLE_OAUTH2_AUTH_EXTRA_ARGUMENTS | {'access_type': 'offline', 'approval_prompt': 'auto'} |
SOCIAL_AUTH_GOOGLE_OAUTH2_KEY | '********************' |
SOCIAL_AUTH_GOOGLE_OAUTH2_SECRET | '********************' |
SOCIAL_AUTH_LOGIN_ERROR_URL | '/' |
SOCIAL_AUTH_PIPELINE | ('social_core.pipeline.social_auth.social_details', 'social_core.pipeline.social_auth.social_uid', 'social_core.pipeline.social_auth.auth_allowed', 'social_core.pipeline.social_auth.social_user', 'social_core.pipeline.user.get_username', 'social_core.pipeline.social_auth.associate_by_email', 'social_core.pipeline.user.create_user', 'social_core.pipeline.social_auth.associate_user', 'social_core.pipeline.social_auth.load_extra_data', 'social_core.pipeline.user.user_details') |
SOCIAL_AUTH_TWITTER_KEY | '********************' |
SOCIAL_AUTH_TWITTER_SECRET | '********************' |
SOUTH_DATABASE_ADAPTERS | {'default': 'south.db.sqlite3'} |
STATICFILES_DIRS | ('/home/trung/nom/media',) |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/home/trung/nom/nom/_media/' |
STATIC_URL | '/media/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/home/trung/nom/nom/templates/'], 'OPTIONS': {'builtins': ['nom.glyph.templatetags.projectfilters'], 'context_processors': ['django.template.context_processors.media', 'django.template.context_processors.static', 'django.template.context_processors.debug', 'django.contrib.messages.context_processors.messages', 'django.contrib.auth.context_processors.auth', 'django.template.context_processors.i18n', 'nom.context_processors.variables', 'django.template.context_processors.request', 'django.template.context_processors.tz', 'social_django.context_processors.backends', 'social_django.context_processors.login_redirect']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'Europe/Berlin' |
USE_ETAGS | False |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | False |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | None |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
YEAR_MONTH_FORMAT | 'F Y' |
You're seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.