Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

JSONDecodeError is not JSON serializable #26

Open
budiantoip opened this issue Dec 26, 2024 · 3 comments
Open

JSONDecodeError is not JSON serializable #26

budiantoip opened this issue Dec 26, 2024 · 3 comments
Milestone

Comments

@budiantoip
Copy link

logparser reported an error in my docker container:

[2024-12-26 12:09:50,917] ERROR    in logparser.logparser: Traceback (most recent call last):
  File "/usr/lib/python3.11/site-packages/logparser/logparser.py", line 467, in run
    data = self.handle_logfile(log_path)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/site-packages/logparser/logparser.py", line 255, in handle_logfile
    self.parse_appended_log(data, appended_log)
  File "/usr/lib/python3.11/site-packages/logparser/logparser.py", line 315, in parse_appended_log
    self.logger.debug("Parsed data_ from appended_log:\n%s", self.json_dumps(data_))
                                                             ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/site-packages/logparser/logparser.py", line 284, in json_dumps
    return json.dumps(obj, ensure_ascii=False, indent=4, sort_keys=sort_keys)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/json/__init__.py", line 238, in dumps
    **kw).encode(obj)
          ^^^^^^^^^^^
  File "/usr/lib/python3.11/json/encoder.py", line 202, in encode
    chunks = list(chunks)
             ^^^^^^^^^^^^
  File "/usr/lib/python3.11/json/encoder.py", line 432, in _iterencode
    yield from _iterencode_dict(o, _current_indent_level)
  File "/usr/lib/python3.11/json/encoder.py", line 406, in _iterencode_dict
    yield from chunks
  File "/usr/lib/python3.11/json/encoder.py", line 406, in _iterencode_dict
    yield from chunks
  File "/usr/lib/python3.11/json/encoder.py", line 439, in _iterencode
    o = _default(o)
        ^^^^^^^^^^^
  File "/usr/lib/python3.11/json/encoder.py", line 180, in default
    raise TypeError(f'Object of type {o.__class__.__name__} '
TypeError: Object of type JSONDecodeError is not JSON serializable

FYI, my container uses the alpine image.

@my8100
Copy link
Owner

my8100 commented Dec 26, 2024

Can you update the settings.py or run logparser with “-v” to print more info?

# The default is False, set it to True to set the logging level from INFO to DEBUG
VERBOSE = False

@budiantoip
Copy link
Author

budiantoip commented Dec 27, 2024

When I run the logparser with the "-v" option inside the container, I only got this output:

****************************************************************************************************
Loading settings from /usr/lib/python3.11/site-packages/logparser/settings.py
****************************************************************************************************


****************************************************************************************************
Visit stats at: http://127.0.0.1:6800/logs/stats.json
****************************************************************************************************

{"downloader/request_bytes": 279,
 "downloader/request_count": 1,
 "downloader/request_method_count/GET": 1,
 "downloader/response_bytes": 379076,
 "downloader/response_count": 1,
 "downloader/response_status_count/200": 1,
 "elapsed_time_seconds": 82.607657,
 "feedexport/success_count/FileFeedStorage": 2,
 "finish_reason": "finished",
 "finish_time": "datetime.datetime(2024, 12, 27, 0, 2, 58, 283984, tzinfo=datetime.timezone.utc)",
 "item_scraped_count": 442,
 "items_per_minute": None,
 "log_count/DEBUG": 448,
 "log_count/INFO": 15,
 "log_count/WARNING": 2,
 "memusage/max": 119156736,
 "memusage/startup": 110751744,
 "response_received_count": 1,
 "responses_per_minute": None,
 "scheduler/dequeued": 1,
 "scheduler/dequeued/memory": 1,
 "scheduler/enqueued": 1,
 "scheduler/enqueued/memory": 1,
 "start_time": "datetime.datetime(2024, 12, 27, 0, 1, 35, 676327, tzinfo=datetime.timezone.utc)"}
Traceback (most recent call last):
  File "/usr/lib/python3.11/site-packages/logparser/common.py", line 163, in parse_crawler_stats
    return json.loads(text)
           ^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/json/__init__.py", line 346, in loads
    return _default_decoder.decode(s)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/json/decoder.py", line 337, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/lib/python3.11/json/decoder.py", line 355, in raw_decode
    raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 12 column 22 (char 486)

However, I got the JSONDecodeError is not JSON serializable message by running a command to filter the container logs, something like this:

docker logs -f my-scrapper 2>&1 | grep "JSONDecodeError is not JSON serializable"

And, the output would be like this:

TypeError: Object of type JSONDecodeError is not JSON serializable
TypeError: Object of type JSONDecodeError is not JSON serializable
TypeError: Object of type JSONDecodeError is not JSON serializable
TypeError: Object of type JSONDecodeError is not JSON serializable
TypeError: Object of type JSONDecodeError is not JSON serializable

I believe that the JSONDecodeError is not JSON serializable error message was triggered by scrapydweb. Hopefully, the above complete logparser output can give you a hint. But, let me know if you need an additional information.

@my8100
Copy link
Owner

my8100 commented Jan 1, 2025

Please try the latest version:
pip install git+https://github.com/my8100/logparser.git@master
or
pip install --upgrade logparser

@my8100 my8100 added this to the 0.8.3 milestone Jan 1, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants