- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了一个恼人的问题。
我做了一个系统,现在用户告诉我它正在给他们这样的信息:
内存不足(需要 268435427 字节)
整个数据库的大小为 12MB,出现问题的查询已经运行了几个月,并没有那么复杂或大。
数据库是innodb。我的服务器有 24GB 内存,所以我严重怀疑它是否真的内存不足。
my.cnf如下:
key_buffer = 8000M
max_allowed_packet = 1M
table_cache = 2048M
sort_buffer_size = 1M
net_buffer_length = 1024M
read_buffer_size = 1M
read_rnd_buffer_size = 24M
innodb_log_file_size = 5M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
innodb_buffer_pool_size = 1024M
innodb_additional_mem_pool_size = 2M
max_connections = 100
query_cache_size = 128M
query_cache_min_res_unit = 1024
query_cache_limit = 16MB
thread_cache_size = 100
max_heap_table_size = 4096MB
在 Windows 任务管理器中查看时,我看到 18.8GB 可用,但只有 100MB 可用。它是 Windows 2008 64 位服务器,这可能是问题的根源吗?
这里是查询:
$currency = '(SELECT currencies.symbol
FROM parts_trading, currencies
WHERE parts_trading.enquiryRef = enquiries.id
AND parts_trading.sellingCurrency = currencies.id
LIMIT 1
)' ;
$amountDueSQL = '(
(SELECT SUM(quantity*(parts_trading.sellingNet
+
parts_trading.sellingVat))
FROM parts_trading
WHERE parts_trading.enquiryRef = enquiries.id
)
+
(SELECT SUM(enquiries_custom_fees.feeAmountNet
+
enquiries_custom_fees.feeAmountVat)
FROM enquiries_custom_fees
WHERE enquiries_custom_fees.enquiryRef = enquiries.id
)
)' ;
$amountPaidSQL = 'COALESCE(
(SELECT SUM(jobs_payments_advance.amount)
FROM jobs_payments_advance
WHERE jobs_payments_advance.jobRef = jobs.id
),
0
)' ;
$result = $dbh->prepare("SELECT SQL_CALC_FOUND_ROWS jobs.id, jobs_states.state, jobs.creationDate, users.username,
entity_details.name, enquiries.id as enquiryId, pendingCancelation,
IF(entity_details.paymentTermsRef = 1, # Outer IF condition
IF($amountDueSQL-$amountPaidSQL = 0.00, # Inner IF condition
CONCAT('Paid in full (', $currency, $amountDueSQL, ')') # Inner IF TRUE
, # End of inner IF TRUE
IF($amountPaidSQL > 0,
CONCAT('Part paid (', $currency, $amountPaidSQL, ')'),
'Unpaid'
)
) # End of inner IF
, # End of TRUE for outer IF
(SELECT entity_payment_terms.term
FROM entity_details, entity_payment_terms
WHERE entity_details.paymentTermsRef
=
entity_payment_terms.id
AND entity_details.id = enquiries.entityRef
) # End of FALSE for outer IF
) AS payState, enquiries.orderNumber,
IF((SELECT COUNT(*)
FROM invoices_out, (SELECT * FROM invoices_out_reference GROUP BY jobRef) AS tb1
WHERE invoices_out.id = tb1.invoiceRef
AND tb1.jobRef = jobs.id) > 1,
'Part-invoiced',
(SELECT invoices_out.date
FROM invoices_out, (SELECT * FROM invoices_out_reference GROUP BY jobRef) AS tb1
WHERE invoices_out.id = tb1.invoiceRef
AND tb1.jobRef = jobs.id)
) AS invoicedDate,
enquiries.id AS enquiryId,
IF((SELECT COUNT(*)
FROM invoices_out, (SELECT * FROM invoices_out_reference GROUP BY jobRef) AS tb1
WHERE invoices_out.id = tb1.invoiceRef
AND tb1.jobRef = jobs.id) > 1,
'Multiple invoices',
(SELECT invoices_out.id
FROM invoices_out, (SELECT * FROM invoices_out_reference GROUP BY jobRef) AS tb1
WHERE invoices_out.id = tb1.invoiceRef
AND tb1.jobRef = jobs.id)
) AS invoiceNumber,
# If the state is 0 (i.e. they have an account, if true find out their payment terms, if false, instead reference the payment state directly.
(SELECT MAX(etaDate) FROM parts_trading WHERE parts_trading.enquiryRef = enquiries.id) AS maxEtaDate,
(SELECT COUNT(DISTINCT DATE(etaDate)) FROM parts_trading WHERE parts_trading.enquiryRef = enquiries.id) AS etaCounts, entity_credit_limits.creditLimit AS cLimit,
COALESCE((SELECT
SUM(qty*parts_trading_buying.buyingNet
/
(SELECT rateVsPound FROM currencies WHERE currencies.id = parts_trading_buying.buyingCurrency))
FROM parts_trading_buying
WHERE parts_trading_buying.enquiryRef = enquiries.id
), 0
) AS nonInvoicedBuyingCosts,
COALESCE((SELECT
SUM(feeAmountNet/(SELECT rateVsPound FROM currencies WHERE currencies.id = parts_trading_buying.buyingCurrency))
FROM parts_trading_buying_charges, parts_trading_buying
WHERE parts_trading_buying_charges.partRef = parts_trading_buying.id
AND parts_trading_buying.enquiryRef = enquiries.id
), 0
) AS nonInvoicedBuyingFeeCosts,
(SELECT
SUM(quantity*parts_trading.sellingNet)
/
COALESCE(
(SELECT invoices_out.rate
FROM invoices_out, invoices_out_reference
WHERE invoices_out.id = invoices_out_reference.invoiceRef
AND invoices_out_reference.jobRef = jobs.id
LIMIT 1),
(SELECT rateVsPound
FROM currencies
WHERE currencies.id = parts_trading.sellingCurrency)
)
FROM parts_trading
WHERE parts_trading.enquiryRef = enquiries.id
) AS sellingParts,
COALESCE((SELECT
SUM(enquiries_custom_fees.feeAmountNet)
/
COALESCE(
(SELECT rate
FROM invoices_out, invoices_out_reference
WHERE invoices_out.id = invoices_out_reference.invoiceRef
AND invoices_out_reference.jobRef = jobs.id LIMIT 1),
(SELECT rateVsPound
FROM currencies
WHERE currencies.id = parts_trading.sellingCurrency
)
)
FROM enquiries_custom_fees, parts_trading
WHERE enquiries_custom_fees.enquiryRef = enquiries.id
AND parts_trading.enquiryRef = enquiries.id), 0) AS sellingFees,
COALESCE((SELECT
SUM(parts_shipping_out.shippingOutCost)
FROM parts_shipping_out, parts_shipping_arrival_dates, parts_shipping_v2
WHERE parts_shipping_out.arrivalsRef = parts_shipping_arrival_dates.id
AND parts_shipping_arrival_dates.shippingRef = parts_shipping_v2.id
AND parts_shipping_v2.jobRef = jobs.id
), 0
) AS actualShippingOutFromEua,
(SELECT
SUM(quantity*parts_trading.sellingNet)
/
COALESCE(
(SELECT invoices_out.rate
FROM invoices_out, invoices_out_reference
WHERE invoices_out.id = invoices_out_reference.invoiceRef
AND invoices_out_reference.jobRef = jobs.id
LIMIT 1),
(SELECT rateVsPound
FROM currencies
WHERE currencies.id = parts_trading.sellingCurrency)
)
+
COALESCE((SELECT
SUM(enquiries_custom_fees.feeAmountNet)
/
COALESCE(
(SELECT rate
FROM invoices_out, invoices_out_reference
WHERE invoices_out.id = invoices_out_reference.invoiceRef
AND invoices_out_reference.jobRef = jobs.id LIMIT 1),
(SELECT rateVsPound
FROM currencies
WHERE currencies.id = parts_trading.sellingCurrency
)
)
FROM enquiries_custom_fees
WHERE enquiries_custom_fees.enquiryRef = enquiries.id), 0)
-
COALESCE((SELECT
SUM(qty*parts_trading_buying.buyingNet
/
(SELECT rateVsPound FROM currencies WHERE currencies.id = parts_trading_buying.buyingCurrency))
FROM parts_trading_buying
WHERE parts_trading_buying.enquiryRef = enquiries.id
), 0
)
-
COALESCE((SELECT
SUM(feeAmountNet/(SELECT rateVsPound FROM currencies WHERE currencies.id = parts_trading_buying.buyingCurrency))
FROM parts_trading_buying_charges, parts_trading_buying
WHERE parts_trading_buying_charges.partRef = parts_trading_buying.id
AND parts_trading_buying.enquiryRef = enquiries.id
), 0
)
-
COALESCE((SELECT
SUM(parts_shipping_out.shippingOutCost)
FROM parts_shipping_out, parts_shipping_arrival_dates, parts_shipping_v2
WHERE parts_shipping_out.arrivalsRef = parts_shipping_arrival_dates.id
AND parts_shipping_arrival_dates.shippingRef = parts_shipping_v2.id
AND parts_shipping_v2.jobRef = jobs.id
), 0
)
FROM parts_trading, parts_trading_buying
WHERE parts_trading.enquiryRef = enquiries.id
AND parts_trading_buying.counterpartRef = parts_trading.id
) AS margin
FROM jobs,
jobs_states, enquiries, users, jobs_payment_status, entity_details
LEFT JOIN entity_credit_limits ON entity_details.id = entity_credit_limits.entityRef
WHERE jobs.stateRef = jobs_states.id
AND IF(paymentStateRef = 0, 1, (jobs_payment_status.id = jobs.paymentStateRef))
# ^ If true it causes a result for each payment state (i.e. 3), so we group on state below, shouldn't cause probs.
AND jobs.enquiryRef = enquiries.id
AND enquiries.entityRef = entity_details.id
AND users.id = enquiries.traderRef
AND enquiries.traderRef = ?
LIMIT ?, ?") ;
如果我尝试将 PHP 执行内存设置为 3.5GB 以上,Apache 将无法启动(我使用的是 xampp)。我必须使用 32 位版本的 PHP 吗?这与 INNODB_BUFFER_POOL_SIZE 相同,我希望它是 14GB,但如果我这样做,mysql 将不会启动。
最佳答案
我不认为这是一个数据库相关的问题,因为这种错误(内存不足(需要 268435427 字节))大多数时候由 PHP 抛出(无限循环或类似的问题可能是问题所在)。
关于mysql - 使用 24GB 服务器的 MySQL 内存不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11339465/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!